MANUFACTURERS REPRESENTATIVES 895 SHERWOOD AVENUE
LOS ALTOS, CALIFORNIA 94022-9990 FOR FREE SAMPLE CALL (415) 941-4525

## 

## 1984

## New Digital Signal Processing Products


(Page 6-3)

- SINGLE CHIP NARROW BAND DOWN CONVERTER
- INPUT SAMPLE RATE = 52 MSPS
- OUTPUT SAMPLE RATE $=82 \mathrm{~Hz}$ TO 459 Hz
- TUNING RESOLUTION $=0.0012 \mathrm{~Hz}$

|  | HSP50016-EV <br> DDC EVALUATION BOARD |
| :---: | :---: |

(Page 8-10)

- PC BASED DATA AND CONTROL
- REAL TIME DATA AND CONTROL
- RAPID PROTOTYPING

(Page 3-43)
- UP/DOWN CONVERSION BY Fs/4
- INTERPOLATION/DECIMATION BY 2
- $\operatorname{SHAPE}$ FACTOR $=1.24$
- PASSBAND RIPPLE < 0.0005dB
- STOPBAND ATTENUATION > 90dB

|  | HSP43124 |
| :---: | :---: |
| 4. | SERIAL VO FILTER |

(Page 3-3)

- 24 BIT INPUT, 32 BIT OUTPUT DATA
- 256 TAP PROGRAMMABLE FIR FILTER
- 5 CASCADED HALF BAND FILTERS


## HSP50110 <br> DIGITAL QUADRATURE TUNER

(Page 6-25)

- FRONT END OF DEMODULATION CHIP SET
- DEMODULATES PSK, FSK, AM, FM
- PROVIDES TUNING, INITIAL FILTERING
- INPUT SAMPLE RATE $=60 \mathrm{MSPS}$
- DATA BITS = 10


## in Hemconolis

## HARRIS SEMICONDUCTOR DSP PRODUCTS

This Digital Signal Processing databook represents the full line of Harris Semiconductor DSP products for commercial and military applications and supersedes previously published DSP material under the Harris, GE, RCA or Intersil names. For a complete listing of all Harris Semiconductor products, please refer to the Product Selection Guide (PSG-201S; ordering information below.)

For complete, current and detailed technical specifications on any Harris devices please contact the nearest Harris sales, representative or distributor office; or direct literature requests to:

Harris Semiconductor Literature Department

Melbourne, FL 32901
TEL: 1-800-442-7747
FAX: (407) 724-3937

## See Section 12 for Data Sheets Available on AnswerFAX

See Technical Assistance Listing on Page vi
U.S. HEADQUARTERS

Harris Semiconductor 1301 Woody Burke Road
Melbourne, Florida 32902
TEL: (407) 724-3000

SOUTH ASIA
Harris Semiconductor H.K. Ltd
13/F Fourseas Building
208-212 Nathan Road
Tsimshatsui, Kowloon
Hong Kong
TEL: (852) 723-6339

EUROPEAN HEADQUARTERS
Harris Semiconductor
Mercure Centre
Rue de la Fusee, 100
1130 Brussels, Belgium
TEL: 3222462111
NORTH ASIA
Harris K.K.
Shinjuku NS Bldg. Box 6153
2-4-1 Nishi-Shinjuku
Shinjuku-Ku, Tokyo 163 Japan
TEL: (81) 3-3345-8911

Harris Semiconductor products are sold by description only. All specifications in this product guide are applicable only to packaged products; specifications for die are available upon request. Harris reserves the right to make changes in circuit design, specifications and other information at any time without prior notice. Accordingly, the reader is cautioned to verify that information in this publication is current before placing orders. Reference to products of other manufacturers are solely for convenience of comparison and do not imply total equivalency of design, performance, or otherwise.

## DIGITAL SIGNAL PROCESSING

## FOR COMMERCIAL AND MILITARY APPLICATIONS

General Information

## Special Function

## TECHNICAL ASSISTANCE

For technical assistance on the Harris products listed in this databook, please contact the Field Applications Engineering staff available at one of the following Harris Sales Offices:

## UNITED STATES

| CALIFORNIA | San Jose . . . . . . . . . . . . . . . . . . . . . . . . . 408-985-7322 |
| :---: | :---: |
|  | Woodland Hills . . . . . . . . . . . . . . . . . . . 818-992-0686 |
| FLORIDA | Melbourne . . . . . . . . . . . . . . . . . . . . . . . 407-723-0501 |
| GEORGIA | Duluth . . . . . . . . . . . . . . . . . . . . . . . . . . . 404-476-2035 |
| ILLINOIS | Schaumburg. . . . . . . . . . . . . . . . . . . . . . 708-240-3480 |
| NEW JERSEY | Voorhees . . . . . . . . . . . . . . . . . . . . . . . 609-751-3425 |
| NEW YORK | Great Neck . . . . . . . . . . . . . . . . . . . . . . . 516-829-9441 |
| INTERNATIONAL |  |
| FRANCE | Paris . . . . . . . . . . . . . . . . . . . . . . . . . 33-1-346-54046 |
| GERMANY | Munich . . . . . . . . . . . . . . . . . . . . . . . . 49-8-963-8130 |
| HONG KONG | Kowloon . . . . . . . . . . . . . . . . . . . . . . . . . 852-723-6339 |
| ITALY | Milano. . . . . . . . . . . . . . . . . . . . . . . . . . 39-2-262-0761 |
| JAPAN | Tokyo . . . . . . . . . . . . . . . . . . . . . . . . 81-33-345-8911 |
| KOREA | Seoul . . . . . . . . . . . . . . . . . . . . . . . . . 82-2-551-0931 |
| SINGAPORE | Singapore . . . . . . . . . . . . . . . . . . . . . . . . 65-291-0203 |
| UNITED KINGDOM | Camberley . . . . . . . . . . . . . . . . . . . . 44-2-766-86886 |

For literature requests, please contact Harris at 1-800-442-7747 (1-800-4HARRIS)

## GENERAL INFORMATION

## ALPHA NUMERIC PRODUCT INDEX

|  |  | PAGE |
| :---: | :---: | :---: |
| DECI•MATETM | Harris HSP43220 Decimating Digital Filter Development Software | 8-3 |
| HMA510 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier Accumulator | 2-3 |
| HMA510/883 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier Accumulator | 2-10 |
| HMU16 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multipliers . | 2-15 |
| HMU17 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multipliers . | 2-15 |
| HMU16/883 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier. | 2-25 |
| HMU17/883 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier. | 2-31 |
| HSP-EVAL | DSP Evaluation Platform. | 8-7 |
| HSP43124 | Serial VO Filter. | 3-3 |
| HSP43168 | Dual FIR Filter. | 3-18 |
| HSP43168/883 | Dual FIR Filter. | 3-35 |
| HSP43216 | Halfband Filter. | 3-43 |
| HSP43220 | Decimating Digital Filter | 3-60 |
| HSP43220/883 | Decimating Digital Filter | 3-83 |
| HSP43481 | Digital Filter. | 3-90 |
| HSP43481/883 | Digital Filter. | 3-105 |
| HSP43881 | Digital Filter. | 3-110 |
| HSP43881/883 | Digital Filter. | 3-125 |
| HSP43891 | Digital Filter. . . . | 3-131 |
| HSP43891/883 | Digital Filter . . . . . . | 3-147 |
| HSP45102 | 12-Bit Numerically Controlled Oscillator. | 5-3 |

[^0]NOTE: Bold Type Designates a New Product from Harris.
$/ 883$ Data Sheet Format - In the interests of conserving space, data sheets for $/ 883$ qualified products have been printed without the Pinouts, Pin Description, Waveforms, AC Test Load Circuit and Design Information sections. The information in these sections can be obtained from the corresponding portion of the commercial data sheets.

## ALPHA NUMERIC PRODUCT INDEX (continued)

PAGE
HSP45106 16-Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16-Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-47
HSP45116-DB HSP45116 Daughter Board ..... 8-8
HSP45240 Address Sequencer. ..... 7-3
HSP45240/883 Address Sequencer. ..... 7-15
HSP45256 Binary Correlator ..... 7-21
HSP45256/883 Binary Correlator ..... 7-34
HSP48212 Digital Video Mixer ..... 4-3
HSP48410 Histogrammer/Accumulating Buffer ..... 4-12
HSP48410/883 Histogrammer/Accumulating Buffer ..... 4-23
HSP48901 $3 \times 3$ Image Filter ..... 4-31
HSP48908 Two Dimensional Convolver ..... 4-40
HSP48908/883 Two Dimensional Convolver ..... 4-57
HSP50016 Digital Down Converter ..... 6-3
HSP50016-EV DDC Evaluation Platform ..... 8-10
HSP50110 Digital Quadrature Tuner ..... 6-25
HSP9501 Programmable Data Buffer ..... 4-64
HSP9520 Multilevel Pipeline Registers ..... 7-42
HSP9521 Multilevel Pipeline Registers ..... 7-42

NOTE: Bold Type Designates a New Product from Harris.
1883 Data Sheet Format - In the interests of conserving space, data sheets for /883 qualified products have been printed without the Pinouts, Pin Description, Waveforms, AC Test Load Circuit and Design Information sections. The information in these sections can be obtained from the corresponding portion of the commercial data sheets.

## PRODUCT INDEX BY FAMILY

PAGE
DEVELOPMENT TOOLS
DECI•MATE ${ }^{\text {TM }} \quad$ Harris HSP43220 Decimating Digital Filter Development Software ..... 8-3
HSP-EVAL DSP Evaluation Platform ..... 8-7
HSP45116-DB HSP45116 Daughter Board ..... 8-8
HSP50016-EV DDC Evaluation Platform. ..... 8-10
DOWN CONVERSION AND DEMODULATION
HSP50016 Digital Down Converter ..... 6-3
HSP50110 Digital Quadrature Tuner ..... 6-25
MULTIPLIERS
HMA510 $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator ..... 2-3
HMADIUIBXU $16 \times 16$-bit ČMŪS raralleı Multiplier Accumulator ..... 2-10
HMU16, HMU17 $16 \times 16$-Bit CMOS Parallel Multipliers ..... 2-15
HMU16/883 $16 \times 16$-Bit CMOS Parallel Multiplier ..... 2-25
HMU17/883 $16 \times 16$-Bit CMOS Parallel Multiplier ..... 2-31
ONE DIMENSIONAL FILTERS
HSP43124 Serial VO Filter ..... 3-3
HSP43168 Dual FIR Filter ..... 3-18
HSP43168/883 Dual FIR Filter ..... 3-35
HSP43216 Halfband Filter ..... 3-43
HSP43220 Decimating Digital Filter ..... 3-60
HSP43220/883 Decimating Digital Filter ..... 3-83
HSP43481 Digital Filter ..... 3-90
HSP43481/883 Digital Filter ..... 3-105
HSP43881 Digital Filter ..... 3-110
HSP43881/883 Digital Filter ..... 3-125
HSP43891 Digital Filter ..... 3-131
HSP43891/883 Digital Filter ..... 3-147

NOTE: Bold Type Designates a New Product from Harris.
/883 Data Sheet Format - In the interests of conserving space, data sheets for $/ 883$ qualified products have been printed without the Pinouts, Pin Description, Waveforms, AC Test Load Circuit and Design Information sections. The information in these sections can be obtained from the corresponding portion of the commercial data sheets.

## PRODUCT INDEX BY FAMILY (continued)

PAGE
SIGNAL SYNTHESIZERS
HSP45102 12-Bit Numerically Controlled Oscillator ..... 5-3
HSP45106 16-Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16-Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-47
SPECIAL FUNCTION
HSP45240 Address Sequencer ..... 7-3
HSP45240/883 Address Sequencer ..... 7-15
HSP45256 Binary Correlator ..... 7-21
HSP45256/883 Binary Correlator ..... 7-34
HSP9520, HSP9521 Multilevel Pipeline Registers ..... 7-42
VIDEO PROCESSING
HSP48212 Digital Vldeo Mixer ..... 4-3
HSP48410 Histogrammer/Accumulating Buffer ..... 4-12
HSP48410/883 Histogrammer/Accumulating Buffer. ..... 4-23
HSP48901 3 x 3 Image Filter ..... 4-31
HSP48908 Two Dimensional Convolver ..... 4-40
HSP48908/883 Two Dimensional Convolver ..... 4-57
HSP9501 Programmable Data Buffer ..... 4-64
NOTE: Bold Type Designates a New Product from Harris.
1883 Data Sheet Format - In the interests of conserving space, data sheets for $/ 883$ qualified products have been printed without the Pinouts,Pin Description, Waveforms, AC Test Load Circuit and Design Information sections. The information in these sectionscan be obtained from the corresponding portion of the commercial data sheets.

## DATA ACQUISITION PRODUCTS

| AVD CONVER | RS - DISPLAY |
| :---: | :---: |
| CA3162 | A/D Converter for 3-Digit Display |
| HI7131, HI7133 | 31/2 Digit Low Power, High CMRR LCD/LED Display Type AD Converter |
| ICL7106, ICL7107 | $31 / 2$ Digit LCD/LED Display A/D Converter |
| ICL7116, ICL7117 | $31 / 2$ Digit LCD/LED Display A/D Converter with Display Hold |
| ICL7126 | 3½ Digit Low Power Single-Chip ADD Converter (AnswerFAX Only) Document \# 3084 See Section 12 |
| ICL7129 | $4 \frac{1}{2}$ 2 Digit LCD Single-Chip A/D Converter |
| ICL7136, ICL7137 | $31 / 2$ Digit LCD/LED Low Power Display AD Converter with Overrange Recovery |
| ICL7139, ICL7149 | $3 \frac{3}{4}$ Digit Autoranging Multimeter |
| ICL8052/ICL71C03, ICL8068/ICL71C03 | Precision $4 \frac{1}{2}$ Digit ADD Converter (AnswerFAX Only) Document \# 3081 See Section 12 |

## A/D CONVERTERS - FLASH

CA3304 CMOS Video Speed 4-Bit Flash ADD Converter
CA3306 CMOS Video Speed 6-Bit Flash ADD Converter
CA3318C CMOS Video Speed 8-Bit Flash A/D Converter
HI1166 8-Bit, 250MSPS Flash AD Converter
HI1276 8-Bit, 500MSPS Flash A/D Converter
HI1386 8-Bit, 75MSPS Flash A/D Converter
HI1396 8-Bit, 125MSPS Flash A/D Converter
HI-5700 8-Bit, 20MSPS Flash AD Converter
HI-5701 6-Bit, 30MSPS Flash AD Converter

## A/D CONVERTERS - INTEGRATING

HI-7159A Microprocessor Compatible 5 $\frac{1}{2}$ Digit AND Converter
ICL7109 12-Bit Microprocessor Compatible A/D Converter
ICL7135 $\quad 4 \frac{1}{2}$ Digit BCD Output A/D Converter
ICL8052/ICL7104,
14/16-Bit $\mu$ P-Compatible, 2-Chip A/D Converter (AnswerFAX Only) Document \# 3091 ICL.8068/ICL7104 See Section 12

NOTE: Bold Type Designates a New Product from Harris.

## DATA ACQUISITION PRODUCTS (continued)

## AD CONVERTERS - SAR

ADC0802, ADC0803, 8-Bit $\mu$ P Compatible ADD Converters ADC0804

| CA3310, CA3310A | CMOS 10-Bit AD Converter with Internal Track and Hold |
| :---: | :---: |
| $\begin{aligned} & \text { HI-574A, } \\ & \text { HI-674A, } \\ & \text { HI-774 } \end{aligned}$ | Complete 12-Bit AD Converter with Microprocessor Interface |
| H15810 | CMOS 10 $\mathbf{4}$ s 12-Bit Sampling AD Converter with Internal Track and Hold |
| H15812 | CMOS 20رs 12-Bit Sampling AD Converter with Internal Track and Hold |
| H15813 | CMOS 3.3V, $25 \mu \mathrm{~s}$ 12-Bit Sampling AD Converter with Internal Track and Hold |
| HI7152 | 10-Bit High Speed A/D Converter with Track and Hold (AnswerFAX Only) Document \# 3100 See Section 12 |
| HI7151 | 10-Bit High Speed AD Converter with Track and Hold (AnswerFAX Only) Document \# 3099 See Section 12 |
| ICL7112 | 12-Bit High-Speed CMOS $\mu$ P-Compatible AD Converter (AnswerFAX Only) Document \# 3639 See Section 12 |
| ICL7115 | 14-Bit High Speed CMOS $\mu$ P-Compatible AND Converter (AnswerFAX Only) Document \# 3101 See Section 12 |

## AD CONVERTERS - SIGMA-DELTA

HI7190 24-Bit High Precision Sigma-Delta AD Converter

A/D CONVERTERS - SUBRANGING

| HI1175 | 8-Bit, 20MSPS Flash AD Converter |
| :--- | :--- |
| HI1176 | 8-Bit, 20MSPS Flash AD Converter |
| HI5800 | 12-Bit, 3MSPS Sampling AND Converter |
| HI-7153 | 8 Channel, 10-Bit High Speed Sampling AND Converter |

## COMMUNICATION INTERFACE

HIN230 thru $\quad+5 \mathrm{~V}$ Powered RS-232 Transmitters/Receivers
HIN241

[^1]
## DATA ACQUISITION PRODUCTS (continued)

## COUNTERS WITH DISPLAY DRIVERS/TIMEBASE GENERATORS

| HA7210 | Low Power Crystal Oscillator |
| :--- | :--- |
| ICM7213 | One Second/One Minute Timebase Generator |
| ICM7216A, | 8-Digit Multi-Function Frequency Counter/Timer |

ICM7216B, ICM7216D
ICM7217 4-Digit LED Display Programmable Up/Down Counter
ICM7224 $\quad 4 \frac{1}{2}$ 2 Digit LCD Display Counter
ICM7226A, ICM7226B8-Digit Multi-Function Frequency Counter/Timers
ICM7249 $\quad 5 \frac{1}{2}$ Digit LCD $\mu$-Power Event/Hour Meter

## D/A CONVERTERS

AD7520, AD7530, 10-Bit, 12-Bit Multiplying D/A Converters
AD7521, AD7531
AD7523, AD7533 8-Bit Multiplying D/A Converters
AD7541 12-Bit Multiplying D/A Converter
AD7545 12-Bit Buffered Multiplying CMOS DAC
CA3338, CA3338A CMOS Video Speed 8-Blt R2R D/A Converter
HI-562A 12-Bit High Speed Monolithic D/A Converter (AnswerFAX Only) Document \# 3580 See Section 12

HI-565A High Speed Monolithic D/A Converter with Reference
HI-DAC80V,
12-Bit, Low Cost, Monolithic D/A Converter
HI-DAC85V
HI1171
HI20201, HI20203
ICL7121

ICL7134 14-Bit Multiplying $\mu$ P-Compatible D/A Converter AnswerFAX Only) Document \# 3113 See Section 12

## DISPLAY DRIVERS

CA3161 BCD to Seven Segment Decoder/Driver
ICM7211, ICM7212 4-Digit ICM7211 (LCD) and ICM7212 (LED) Display Drive
ICM7228 8-Digit $\mu$ P Compatible LED Display Decoder Driver
ICM7231, ICM7232 Numeric/Alphanumeric Triplexed LCD Display Driver
ICM7243 8-Character $\mu$ P-Compatible LED Display Decoder Driver

NOTE: Bold Type Designates a New Product from Harris.

## DATA ACQUISITION PRODUCTS (Continued)

## MULTIPLEXERS

| DG406, DG407 | Single 16-Channel/Differential 8-Channel CMOS Analog Multiplexers |
| :---: | :---: |
| DG408, DG409 | Single 8-Channel/Differential 4-Channel CMOS Analog Multiplexers |
| DG458, DG459 | Single 8-Channel/Differential 4-Channel Fault Protected Analog Multiplexers |
| DG506A, DG507A, DG508A, DG509A | CMOS Analog Multiplexers |
| DG526, DG527, DG528, DG529 | Analog CMOS Latchable Multiplexers |
| HI-1818A, HI-1828A | Low Resistance, Single 8 Channel and Differential 4 Channel CMOS Analog Multiplexers |
| $\begin{aligned} & \mathrm{HI}-506, \mathrm{HI}-507 \text {, } \\ & \mathrm{HI}-508, \mathrm{HI}-509 \end{aligned}$ | Single 16 and 8/Differential 8 and 4 Channel CMOS Analog Multiplexers |
| HI-506A, HI-507A, HI-508A, HI-509A | 16 Channel, 8 Channel, Differential 8 and Differential 4 Channel CMOS Analog MUXs with Active Overvoltage Protection |
| HI-516 | 16 Channel/Differential 8 Channel CMOS High Speed Analog Multiplexer |
| HI-518 | 8 Channel/Differential 4 Channel CMOS High Speed Analog Multiplexer |
| HI-524 | 4 Channel Wideband and Video Multiplexer |
| HI-539 | Monolithic, 4 Channel, Low Level, Differential Multiplexer |
| $\begin{aligned} & \text { HI-546, HI-547, } \\ & \text { HI-548, HI-549 } \end{aligned}$ | Single 16 and 8, Differential 8 and 4 Channel CMOS Analog MUXs with Active Overvoltage Protection |
| IH6108 | 8-Channel CMOS Analog Multiplexer (AnswerFAX Only) Document \# 3156 See Section 12 |
| IH6208 | 4-Channel Differential CMOS Analog Multiplexer (AnswerFAX Only) Document \# 3157 See Section 12 |
| SPECIAL PURPOSE |  |
| AD590 | 2 Wire Current Output Temperature Transducer |
| ICL8069 | Low Voltage Reference |
| ICM7170 | $\mu \mathrm{P}$-Compatible Real-Time Clock |

NOTE: Bold Type Designates a New Product from Harris.

## DATA ACQUISITION PRODUCTS (Continued)

## SWITCHES

DG181 thru DG191 High-Speed Driver with JFET Switch (AnswerFAX Only) Document \# 3114 See Section 12 DG200, DG201 CMOS Dual/Quad SPST Analog Switches
DG201A, DG202 Quad SPST CMOS Analog Switches
DG211, DG212 SPST 4 Channel Analog Switch
DG300A, DG301A, TTL Compatible CMOS Analog Switches
DG302A, DG303A
DG308A, DG309 Quad Monolithic SPST CMOS Analog Switches
DG401, DG403, Monolithic CMOS Analog Switches DG405

DG411, DG412, DG413

DG441, DG442
Monolithic Quad SPST CMOS Analog Switches

Monolithic Quad SPST CMOS Analog Switches
DG444, DG445
Monolithic Quad SPST CMOS Analog Switches
HI-200, HI-201 Dual/Quad SPST CMOS Analog Switches
HI-201HS High Speed Quad SPST CMOS Analog Switch
HI-222 High Frequency/Video Switch (AnswerFAX Only) Document \# 3124 See Section 12
HI-300 thru CMOS Analog Switches
HI-307
HI-381 thru CMOS Analog Switches
HI-390
HI-5040 thru HI-5051, HI-5046A
and HI-5047A
IH401A
IH5009 thru IH5012, IH5014, IH5016 thru IH5020, IH5022, IH5024

IH5043 Dual SPDT CMOS Analog Switch
IH5052, IH5053 Quad CMOS Analog Switch
IH5140 thru IH5145
IH5151
High-Level CMOS Analog Switch

IH5341, IH5352
Dual SPDT CMOS Analog Switch

IH6201

## LINEAR AND TELECOM PRODUCTS

## COMPARATORS DATA SHEETS

CA139, CA239, Quad Voltage Comparators for Industrial, Commercial and Military Applications
САЗ39, LM339
CA3098 Programmable Schmitt Trigger - with Memory Dual Input Precision Level Detectors
CA3290 BiMOS Dual Voltage Comparator with MOSFET Input, Bipolar Output
HA-4900, HA-4902, Precision Quad Comparator
HA-4905
HFA-0003, Ultra High Speed Comparator

## HFA-0003L

## DIFFERENTIAL AMPLIFIERS DATA SHEETS

CA3028, CA3053 DifferentiaVCascode Amplifiers for Commercial and Industrial Equipment from DC to $\mathbf{1 2 0 M H z}$
CA3049, CA3102 Dual High Frequency Differential Amplifiers For Low Power Applications Up 500MHz
CA3054 Transistor Array - Dual Independent Differential Amp for Low Power Applications from DC to 120 MHz

## OPERATIONAL AMPLIFIERS DATA SHEETS

CA124, CA224, CA324, LM324*, LM2902*

CA158, CA258, CA358, CA2904, LM358*, LM2904*

CA741, CA1458, CA1558, LM741*, LM1458*, LM1558*

CA3020 Multipurpose Wide-Band Power Amps Military, Industrial and Commercial Equipment at Frequency Up to 8 MHz

CA3060 Operational Transconductance Amplifier Arrays
CA3078 Micropower Operational Amplifier
CA3080 Operational Transconductance Amplifier (OTA)
CA3094 Programmable Power Switch/Amplifier for Control and General Purpose Applications
CA3100 Wideband Operational Amplifier
CA3130 BiMOS Operational Amplifier with MOSFET Input/CMOS Output
CA3140 BiMOS Operational Amplifier with MOSFET Input/Bipolar Output
CA3160 BiMOS Operational Amplifiers with MOSFET Input/CMOS Output
CA3193 BiCMOS Precision Operational Amplifiers
CA3240 Dual BiMOS Operational Amplifier with MOSFET Input/Bipolar Output
CA3260 BiMOS Operational Amplifier with MOSFET Input/CMOS Output
CA3280 Dual Variable Operational Amplifier

NOTE: Bold Type Designates a New Product from Harris.

## LINEAR AND TELECOM PRODUCTS (contuuad)

OPERATIONAL AMPLIFIERS DATA SHEETS (Continued)
CA3420
Low Supply Voltage, Low Input Current BiMOS Operational Amplifiers
CA3440
CA3450
CA5130 BiMOS Microprocessor Operational Amplifier with MOSFET Input/CMOS Output
CA5160 BiMOS Microprocessor Operational Amplifiers with MOSFET Input/CMOS Output
CA5260 BiMOS Microprocessor Operational Amplifiers with MOSFET Input/CMOS Output
CA5420
Low Supply Voltage, Low Input Current BiMOS Operational Amplifier
CA5470 Quad Microprocessor BiMOS-E Operational Amplifiers with MOSFET Input/Bipolar Output
HA-2400, HA-2404, HA-2405

HA-2406
HA-2444
Digitally Selectable Four Channel Operational Amplifier

HA-2500, HA-2502, HA-2505

HA-2510, HA-2512, HA-2515

HA-2520, HA-2522,
Selectable, Four Channel Video Operational Amplifier HA-2525

HA-2529 Uncompensated, High Slew Rate High Output Current, Operational Amplifier
HA-2539 Very High Siew Rate Wideband Operational Amplifier
HA-2540 Wideband, Fast Settling Operational Amplifier
HA-2541 Wideband, Fast Settling, Unity Gain Stable, Operational Amplifier
HA-2542 Wideband, High Slew Rate, High Output Current Operational Amplifier
HA-2544 Video Operational Amplifier
HA-2548 Precision, High Slew Rate, Wideband Operational Amplifier
HA-2600, HA-2602, Wideband, High Impedance Operational Amplifiers HA-2605

HA-2620, HA-2622, HA-2625

HA-2640, HA-2645
High Voltage Operational Amplifiers
HA-2705 Low Power, High Performance Operational Amplifier
HA-2839 Very High Slew Rate Wideband Operational Amplifier
HA-2840 Very High Slew Rate Wideband Operational Amplifier
HA-2841 Wideband, Fast Settling, Unity Gain Stable, Video Operational Amplifier
HA-2842 Wideband, High Slew Rate, High Output Current, Video Operational Amplifier
HA-2850 Low Power, High Slew Rate Wideband Operational Amplifier

NOTE: Bold Type Designates a New Product from Harris.

## LINEAR AND TELECOM PRODUCTS (contnued)

| HA-4741 | Quad Operational Amplifier |
| :---: | :---: |
| HA-5002 | Monolithic, Wideband, High Slew Rate, High Output Current Buffer |
| HA-5004 | 100MHz Current Feedback Amplifier |
| HA-5020 | 100MHz Current Feedback Video Amplifier |
| HA5022, HA5024 | Dual, Quad 100MHz Video Current Feedback Amplifier with Disable |
| HA5023, HA5025 | Dual, Quad 100MHz Video Current Feedback Amplifier |
| HA-5033 | Video Buffer |
| HA-5101, HA-5111 | Low Noise, High Performance Operational Amplifiers |
| HA-5102, HA-5104, HA-5112, HA-5114 | Low Noise, High Performance Operational Amplifiers |
| HA-5127 | Ultra-Low Noise Precision Operational Amplifier |
| HA-5130, HA-5135 | Precision Operational Amplifiers |
| HA-5134 | Precision Quad Operational Amplifier |
| HA-5137 | Ultra-Low Noise Precision Wideband Operational Amplifier |
| HA-5142, HA-5144 | DuaVQuad Ultra-Low Power Operational Amplifiers |
| HA-5147 | Ultra-Low Noise Precision High Slew Rate Wideband Operational Amplifier |
| HA-5160, HA-5162 | Wideband, JFET Input High Slew Rate, Uncompensated, Operational Amplifiers |
| HA-5170 | Precision JFET Input Operational Amplifier |
| HA-5177 | Ultra-Low Offset Voltage Operational Amplifier |
| HA-5190, HA-5195 | Wideband, Fast Settling Operational Amplifiers |
| HA-5221, HA-5222 | Low Noise, Wideband Precision Operational Amplifiers |
| HA5232, HA5234 | Precision Dual and Quad Operational Ampllfiers |
| HFA-0001 | Ultra High Slew Rate Operational Amplifier |
| HFA-0002 | Low Noise Wideband Operational Amplifier |
| HFA-0005 | High Slew Rate Operational Amplifier |
| HFA1100, HFA1120 | Ultra High-Speed Current Feedback Amplifiers |
| HFA1105, HFA1106, HFA1135, HFA1145 | High-Speed, Low Power, Current Feedback Operational Amplifiers |
| HFA1110 | 750MHz Low Distortion Unity Gain, Closed Loop Buffer |
| HFA1112 | Ultra High-Speed Closed Loop Buffer Amplifier |
| HFA1113 | High-Speed, Output Clamping Closed Loop Buffer |
| HFA1130 | Output Clamping, Ulira High-Speed Current Feedback Amplifier |
| ICL7611, ICL7612 | ICL76XX Series Low Power CMOS Operational Amplifiers |
| ICL7621, ICL7641, ICL7642 | ICL76XX Series Low Power CMOS Operational Amplifiers |
| ICL7650S | Super Chopper-Stabilized Operational Amplifier |

NOTE: Bold Type Designates a New Product from Harris.

## LINEAR AND TELECOM PRODUCTS (continued)

## SAMPLE AND HOLD AMPLIFIER DATA SHEETS

HA-2420, HA-2425

HA-5320 High Speed Precision Monolithic Sample and Hold Amplifier HA-5330 Very High Speed Precision Monolithic Sample and Hold Amplifier

HA5350, HA5351
HA5352
Fast Sample and Hold Amplifiers High Speed, Low Distortion, Precision Monolithic Sample and Hold Amplifier Ultra Fast (50ns) Sample and Hold Amplifiers

Ultra Fast (50ns) Dual Sample and Hold Amplifier

## SPECIAL ANALOG CIRCUITS DATA SHEETS

CA555, LM555 Timers for Timing Delays and Oscillator Applications in Commercial, Industrial and Military Equipment
CA1391, CA1394
CA3089
CA3126 TV Chroma Processor
CA3189 FM IF System
CA3194 Single Chip PAL Luminance/Chroma Processor
CA3217 Single Chip TV Chroma/Luminance Processor
CA3256 BiMOS Analog Video Switch and Amplifier
CD22402 Sync Generator for TV Applications and Video Processing Systems
HA-2546 Wideband Two Quadrant Analog Multiplier
HA-2547 Wideband Two Quadrant Analog Multiplier
HA-2556 Wideband Four Quadrant Voltage Output Analog Multiplier
HA-2557 Wideband Four Quadrant Current Output Analog Multiplier
HA7210 Low Power Crystal Oscillator
HFA5250 Ultra High-Speed Monolithic Pin Driver
ICL8013 Four Quadrant Analog Multiplier
ICL8038 Precision Waveform Generator/Voltage Controlled Oscillator
ICL8048, ICL8049 Log/Antilog Amplifiers
ICM7242 Long Range Fixed Timer
ICM7555, ICM7556 General Purpose Timers

## TELECOMMUNICATIONS DATA SHEETS

CD22100 CMOS $4 \times 4$ Crosspoint Switch with Control Memory High-Voltage Type (20V Rating)
CD22101, CD22102 CMOS $4 \times 4 \times 2$ Crosspoint Switch with Control Memory
CD22103A CMOS HDB3 (High Density Bipolar 3) Transcoder for 2.048/8.448 Mb/s Transmission Applications
CD22202, CD22203 5V Low Power DTMF Receiver

NOTE: Bold Type Designates a New Product from Harris.

# LINEAR AND TELECOM PRODUCTS (continued) 

| TELECOMMUNICATIONS DATA SHEETS (continued) |  |
| :---: | :---: |
| CD22204 | 5V Low Power Subscriber DTMF Receiver |
| CD22301 | Monolithic Pan Repeater |
| CD22354A, CD22357A | CMOS Single-Chip, Full-Feature PCM CODEC |
| CD22M3493 | $12 \times 8 \times 1$ BIMOS-E Crosspoint Switch |
| CD22M3494 | $16 \times 8 \times 1$ BIMOS-E Crosspoint Switch |
| CD22859 | Monolithic Silicon COS/MOS Dual-Tone Multifrequency Tone Generator |
| CD74HC22106, CD74HCT22106 | QMOS $8 \times 8 \times 1$ Crosspoint Switch with Memory Control |
| HC-5502B | SLCC Subscriber Line Interface Clircuit |
| HC-5504B | SLIC Subscriber Line Interface Clircuit |
| HC-5504DLC | SLIC Subscriber Line Interface Circuit |
| HC-5509A1 | SLIC Subscriber Line Interface Clircuit |
| HC-5509B | SLIC Subscriber Line Interface Clicult |
| HC-5524 | SLIC Subscriber Line Interface Circuit |
| HC-5560 | PCM Transcoder |
| HC-55536 | Continuous Variable Slope Delta-Demodulator (CVSD) |
| HC-55564 | Continuously Variable Slope Delta-Modulator (CVSD) |
| TRANSISTOR ARRAY DATA SHEETS |  |
| CA3018 | General Purpose Transistor Arrays |
| CA3039 | Diode Array |
| CA3045, CA3046 | General Purpose N-P-N Transistor Arrays |
| CA3081, CA3082 | General Purpose High Current N-P-N Transistor Arrays |
| CA3083 | General Purpose High Current N-P-N Transistor Array |
| CA3086 | General Purpose N-P-N Transistor Array |
| CA3096 | N-P-N/P-N-P Transistor Array |
| CA3127 | High Frequency N-P-N Transistor Array |
| CA3141 | High-Voltage Diode Array For Commercial, Industrial \& Military Applications |
| CA3146, CA3183 | High-Voltage Transistor Arrays |
| CA3227, CA3246 | High-Frequency N-P-N Transistor Arrays For Low-Power Applications at Frequencies Up to 1.5GHz |
| HFA3046, HFA3096, HFA3127, HFA3128 | Ulitra High Frequency Transistor Array |
| NOTE: Bold Type Designates a New Product from Harris. |  |



MULTIPLIERS

PAGE

| HMA510 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier Accumulator | 2-3 |
| :---: | :---: | :---: |
| HMA510/883 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multiplier Accumulator | 2-10 |
| HMU16, HMU17 | $16 \times 16-\mathrm{Bit}$ CMOS Parallel Multipliers | 2-15 |
| HMU16/883 | $16 \times 16-$ Bit CMOS Parallel Multiplier. | 2-25 |
| HMU17/883 | $16 \times 16$-Bit CMOS Parallel Multiplier. | 2-31 |

## $16 \times 16$-Bit CMOS Parallel <br> Multiplier Accumulator

## Features

- $16 \times 16$-bit Parallel Multiplication with Accumulation to a 35-Bit Result
- High-Speed (45ns) Multiply Accumulate Time
- Low Power CMOS Operation:
- $I_{\text {ccsB }}=500 \mu \mathrm{~A}$ Maximum
- $I_{\text {CCOP }}=7.0 \mathrm{~mA}$ Maximum at 1.0 MHz
- HMA510 is Compatible with the CY7C510 and the IDT7210
- Supports Two's Complement or Unsigned Magnitude Operations
- TTL Compatible Inputs/Outputs
- Three-State Outputs


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HMA510JC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMA510JC-55 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMA510GC-55 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HMA510 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier accumulator capable of operating at 45 ns clocked multiply-accumulate cycles. The 16-bit X and Y operands may be specified as either two's complement or unsigned magnitude format. Additional inputs are provided for the accumulator functions which include: loading the accumulator with the current product, adding or subtracting the accumulator contents and the current product, and preloading the accumulator registers from the external inputs.

All inputs and outputs are registered. The registers are all positive edge triggered, and are latched on the rising edge of the associated clock signal. The 35 -bit accumulator output register is broken into three parts. The 16-bit least significant product (LSP), the 16 -bit most significant product (MSP), and the 3 -bit extended product (XTP) registers. The XTP and MSP registers have dedicated output ports, while the LSP register shares the Y -inputs in a multiplexed fashion. The entire 35-bit accumulator output register may be preloaded at any time through the use of the bidirectional output ports and the preloaded control.

Block Diagram


HMA510

Pinouts
HMA510 PLCC


HMA510 CERAMIC PGA


HMA510

## Pin Descriptions

| NAME | PLCC PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 17-20 |  | The +5 V power supply pins. $0.1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | 53,54 |  | The device ground. |
| X0-X15 | 1-10,63-68 | 1 | X-Input Data. These 16 data inputs provide the multiplicand which may be in two's complement or unsigned magnitude format. |
| $\begin{aligned} & \text { Yo-Y15/ } \\ & \text { PO-P15 } \end{aligned}$ | 45-52,55-62 | 1/0 | Y-Input/LSP Output Data. This 16 -bit port is used to provide the multiplier which may be in two's complement or unsigned magnitude format. It may also be used for output of the Least Significant Product (PO-P15) or for preloading the LSP register. |
| P16-P3 | 29-44 | I/O | MSP Output Data. This 16-Bit port is used to provide the Most Significant Product Output (P16-P31). It may also be used to preload the MSP register. |
| P32-P34 | 26-28 | 1/O | XTP Output Data. This 3-Bit port is used to provide the Extended Product Output (P32-P34). It may also be used to preload the XTP register. |
| TC | 21 | I | Two's Complement Control. Input data is interpreted as two's complement when this control is HIGH. A LOW indicates the data is to be interpreted as unsigned magnitude format. This control is latched on the rising edge of CLKX or CLKY. |
| ACC | 14 | 1 | Accumulate Control. When this control is HIGH, the accumulator output register contents are added to or subtracted from the current product, and the result is stored back into the accumulator output register. <br> When LOW, the product is loaded into the accumulator output register overwriting the current contents. This control is also latched on the rising edge of CLKX or CLKY. |
| SUB | 13 | 1 | Subtract Control. When both SUB and ACC are HIGH, the accumulator register contents are subtracted from the current product. When ACC is HIGH and SUB is LOW, the accumulator register contents and the current product are summed. The SUB control input is latched on the rising edge of CLKX or CLKY. |
| RND | 12 | 1 | Round Control. When this control is HIGH, a one is added to the most significant bit of the LSP. When LOW, the product is unchanged. |
| PREL | 23 | 1 | Preload Control. When this control is HIGH, the three bidirectional ports may be used to preload the accumulator registers. The three-state controls ( $\overline{\mathrm{OEX}}, \overline{\mathrm{OEM}}$, $\overline{O E L}$ ) must be HIGH, and the data will be preloaded on the rising edge of CLKP. When this control is LOW, the accumulator registers function in a normal manner. |
| $\overline{O E L}$ | 11 | 1 | Y-Input/LSP Output Port Three-state Control. When $\overline{\mathrm{OEL}}$ is HIGH, the output drivers are in the high impedance state. This state is required for Y -data input or preloading the LSP register. When OEL is LOW, the port is enabled for LSP output. |
| $\overline{\text { OEM }}$ | 24 | I | MSP Output Port Three-state Control. A LOW on this control line enables the port for output. When $\overline{\mathrm{OEM}}$ is HIGH , the output drivers are in the high impedance state. This control must be HIGH for preloading the MSP register. |
| $\overline{O E X}$ | 22 | I | XTP Output Port Three-state Control. A LOW on this control line enables the port for output. When $\overline{O E X}$ is HIGH, the output drivers are in the high impedance state. This control must be HIGH for preloading the XTP register. |
| CLKX | 15 | 1 | X-Register Clock. The rising edge of this clock latches the X-data input register along with the TC, ACC, SUB and RND inputs. |
| CLKY | 16 | 1 | Y-Register Clock. The rising edge of this clock latches the Y-data input register along with the TC, ACC, SUB and RND inputs. |
| CLKP | 25 | 1 | Product Register Clock. The rising edge of CLKP latches the LSP, MSP and XTP registers. If the preload control is active, the data on the I/O ports is loaded into these registers. If preload is not active, the accumulated product is loaded into the the registers. |

## Functional Description

The HMA510 is a high speed $16 \times 16$-bit multiplier accumulator (MAC). It consists of a 16-bit parallel multiplier follower by a 35-bit accumulator. All inputs and outputs are registered and are latched on the rising edge of the associated clock signal. The HMA510 is divided into four sections: the input section, the multiplier array, the accumulator and the output/preload section.

The input section has two 16-bit operand input registers for the $X$ and $Y$ operands which are latched on the rising edge of CLKX and CLKY respectively. A four bit control register (TC, RND, ACC, SUB) is also included and is latched from either of the input clock signals.

The $16 \times 16$ multiplier array produces the 32-bit product of the input operands. Two's complement or unsigned magnitude operation can be selected by the use of the TC control. The 32-bit result may also be rounded through the use of the RND control. In this case, a ' 1 ' is added to the MSB of the LSP (bit P15). The 32-bit product is zero-filled or sign-extened as appropriate and passed as a 35-bit number to the accumulator section.

The accumulator functions are controlled by the ACC, SUB and PREL control inputs. Four functions may be selected: the accumulator may be loaded with the current product; the product may be added to the accumulator contents; the accumulator contents may be subtracted from the current product; or the accumulator may be loaded from the bidirectional ports. The accumulator registers are updated at the rising edge of the CLKP signal.

The output/preload section contains the accumulator/ output register and the bidirectional ports. This section is controlled by the signals PREL, $\overline{O E X}, \overline{\mathrm{OEM}}$ and $\overline{\mathrm{OEL}}$. When PREL is high, the output buffers are in a high impedance state. When one of the controls $\overline{\mathrm{OEX}}, \overline{\mathrm{OEM}}$ or $\overline{\mathrm{OEL}}$ are also high, data present at the outputs will be preloaded into the associated register on the rising edge of CLKP. When PREL is low, the signals $\overline{\mathrm{OEX}}, \overline{\mathrm{OEM}}$ and $\overline{\mathrm{OEL}}$ are enable controls for their respective three-state output ports.

PRELOAD FUNCTION TABLE

| PREL | $\overline{O E X}$ | $\overline{\text { OEM }}$ | OEL | OUTPUT REGISTERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | XTP | MSP | LSP |
| 0 | 0 | 0 | 0 | Q | Q | Q |
| 0 | 0 | 0 | 1 | Q | Q | z |
| 0 | 0 | 1 | 0 | Q | Z | Q |
| 0 | 0 | 1 | 1 | Q | Z | z |
| 0 | 1 | 0 | 0 | Z | Q | Q |
| 0 | 1 | 0 | 1 | Z | Q | z |
| 0 | 1 | 1 | 0 | z | z | Q |
| 0 | 1 | 1 | 1 | z | z | z |
| 1 | 0 | 0 | 0 | Z | z | Z |
| 1 | 0 | 0 | 1 | z | Z | PL |
| 1 | 0 | 1 | 0 | z | PL | Z |
| 1 | 0 | 1 | 1 | z | PL | PL |
| 1 | 1 | 0 | 0 | PL | Z | z |
| 1 | 1 | 0 | 1 | PL | Z | PL |
| 1 | 1 | 1 | 0 | PL | PL | Z |
| 1 | 1 | 1 | 1 | PL | PL | PL |

Z = Output Buffers at High Impedance (Disabled).
$Q=$ Output Buffers at LOW Impedance. Contents of Output Register Available Through Output Ports.
PL = Output disabled. Preload data supplied to the output pins will be loaded into the register at the rising edge of CLKP.

ACCUMULATOR FUNCTION TABLE

| PREL | ACC | SUB | P | OPERATION |
| :---: | :---: | :---: | :---: | :--- |
| L | L | X | Q | Load |
| L | H | L | Q | Add |
| L | H | H | Q | Subtract |
| H | X | X | PL | Preload |

## INPUT FORMATS

Fractional Two's Complement Input


Unsigned Fractional Input


## Unsigned Integer Input



## OUTPUT FORMATS

Two's Complement Fractional Output


## Unsigned Fractional Output



## Unsigned Integer Output

## XTP

MSP

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |



| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 215 | 214 | 213 | 212 | 211 | 210 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 |

## Specifications HMA510

## Absolute Maximum Ratings

Supply Voltage
$+8.0 \mathrm{~V}$
Input, Output or I/O Voltage Applied .... GND -0.5 V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ Storage Temperature Range . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Gate Count Junction Temperature $\ldots \ldots . . .150^{\circ} \mathrm{C}$ (PLCC), $+175^{\circ} \mathrm{C}$ (PGA) Lead Temperature (Soldering, Ten Seconds) .............. $+300^{\circ} \mathrm{C}$ ESD Classification . Class 1

## Operating Condltions

Operating Voltage Range
+4.75 V to +5.25 V
Operating Temperature Range
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Reliability Information
$\theta_{\text {ja }} \ldots \ldots \ldots . . . . . . . . . . . . .$.
 Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$. ..... 1.7W (PLCC)
2.46/W (PGA)
D.C. Electrical Specificatlons ( $\mathrm{V}_{\mathbf{C C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | $\mathrm{I}_{\mathrm{I}}$ | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output or I/O Leakage Current | IO | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $\mathrm{I}_{\mathrm{CCSB}}$ | - | 500 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Outputs Open |
| Operating Power Supply Current | $\mathrm{I}_{\mathrm{CCOP}}$ | - | 7.0 | mA | $\mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ <br> (Note 1$)$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 10 | pF |  |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 10 | pF |  |
| I/O Capacitance | $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | - | 15 | pF |  |

NOTES:

1. Operating Supply Current is proportional to frequency, typical rating is $\quad$ 2. Not tested, but characterized at initial design and at major process/design $5.0 \mathrm{~mA} / \mathrm{MHz}$. changes.
A.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | HMA510-45 |  | HMA510-55 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Multiply Accumulate Time | TMA | - | 45 | - | 55 | ns |  |
| Output Delay | TD | - | 25 | - | 30 | ns |  |
| 3-State Enable Time | TENA | - | 25 | - | 30 | ns | Note 1 |
| 3-State Disable Time | TDIS | - | 25 | - | 30 | ns | Note 1 |
| Input Setup Time | $\mathrm{T}_{\text {S }}$ | 18 | - | 20 | - | ns |  |
| Input Hold Time | $\mathrm{T}_{\mathrm{H}}$ | 2 | - | 2 | - | ns |  |
| Clock High Puise Width | TPWH | 15 | - | 20 | - | ns |  |
| Clock Low Pulse Width | TPWL | 15 | - | 20 | - | ns |  |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 8 | - | 8 | ns | From 0.8 V to 2.0 V |
| Output Fall Time | $T_{F}$ | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading specified in A.C. Test Circuit; $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. For A.C. Test load, refer to A.C. Test Circuit with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
[^2]
## A.C. Test Circuit


*Includes Stray and Jig Capacitance
A.C. Testing Input, Output Waveforms

A.C. Testing: All Parameters tested as per test circuit. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.

## Timing Diagram




THREE STATE CONTROL


PRELOAD TIMING DIAGRAM


## $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-bit Parallel Multiplication with Accumulation to a 35-Bit Result
- High-Speed (55ns) Multiply Accumulate Time
- Low Power CMOS Operation
- $I_{\text {CcsB }}=500 \mu \mathrm{~A}$ Maximum
- $I_{\text {Ccop }}=7.0 \mathrm{~mA}$ Maximum at 1.0 MHz
- HMA510/883 is Compatible with the CY7C510 and the IDT7210
- Supports Two's Complement or Unsigned Magnitude Operations
- Three-State Outputs

Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HMA510GM-55/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMA510GM-65/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMA510GM $-75 / 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HMA510/883 is a high speed, low power CMOS $16 \times$ 16-bit parallel multiplier accumulator capable of operating at 55ns clocked multiply-accumulate cycles. The 16-bit $X$ and $Y$ operands may be specified as either two's complement or unsigned magnitude format. Additional inputs are provided for the accumulator functions which include: loading the accumulator with the current product, adding or subtracting the accumulator contents and the current product, and preloading the accumulator registers from the external inputs.
All inputs and outputs are regisfered. The registers are all positive edge triggered, and are latched on the rising edge of the associated clock signal. The 35 -bit accumulator output register is broken into three parts. The 16-bit least significant product (LSP), the 16 -bit most significant product (MSP), and the 3-bit extended product (XTP) registers. The XTP and MSP registers have dedicated output ports, while the LSP register shares the Y -inputs in a multiplexed fashion. The entire 35-bit accumulator output register may be preloaded at any time through the use of the bidirectional output ports and the preloaded control.

## Block Diagram



\author{

Absolute Maximum Ratings <br> Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V <br> Input or Output Voltage Applied ........ GND-0.5V to $\mathrm{V}_{\mathrm{CC}}{ }^{+0.5 \mathrm{~V}}$ <br> Storage Temperature Range..................${ }^{-65}{ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ <br> Lead Temperature (Soldering 10 sec ) ...................... $300^{\circ} \mathrm{C}$ <br> ESD Classification <br> Class 1 <br> CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. <br> Reliability Information <br> | Thermal Resistance | $\theta_{j a}$ | $\theta_{\mathrm{jc}}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package . | $43^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package . |  | 17 Watt |
| Gate Count |  | 0 Gates |

## Operating Conditions


Operating Temperature Range . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HMA510/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $V_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{v}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ${ }^{\text {I CCSB }}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND, <br> $V_{C C}=5.5 \mathrm{~V}$, Outputs <br> Open | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | I'COP | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}(\text { Note } 2) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.

TABLE 2. HMA510/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -55 |  | -65 |  | -75 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Multiply Accumulate Time | TMA |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 55 | - | 65 | - | 75 | ns |
| input Setup Time | Ts |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Clock LOW <br> Pulse Width | ${ }^{\text {TPWL }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\mathrm{T}} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Output Delay | TD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 35 | - | 35 | ns |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 30 | - | 35 | ns |

NOTES:

1. AC Testing as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels $O \mathrm{~V}$ and 3.0 V ( OV and 3.2 V for clock inputs). Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 3. HMA510/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | -55 |  | -65 |  | -75 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cl}_{\mathrm{IN}}$ | $V_{C C}=$ Open, $f=1 \mathrm{MHz}$ All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| 1/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | - | 15 | pF |
| Input Hold Time | $\mathrm{TH}_{\mathrm{H}}$ |  | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | 3 | - | ns |
| 3-State Disable Time | TDIS |  | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 30 | - | 30 | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | ns |
| Output Fall Time | $T_{F}$ | From 2.0 V to 0.8 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | ns |

## NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

CAUTION: These devices are sensitive to electrostatic discharge. Proper IC handling procedures should be followed.

Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X6 | F1 | F1 | Y9/P9 | F2 | K7 | P26 | $\mathrm{v}_{\mathrm{CC} / 2}$ | E11 | ACC | F1 |
| A6 | X5 | F2 | G2 | Y10/P10 | F3 | L7 | P27 | $\mathrm{v}_{\mathrm{CC} / 2}$ | D10 | SUB | F2 |
| 85 | X4 | F3 | G1 | Y11/P11 | F5 | K8 | P28 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D11 | RND | F3 |
| A5 | X3 | F4 | H2 | Y12/P12 | F4 | L8 | P29 | $\mathrm{v}_{\mathrm{cc} / 2}$ | C10 | $\overline{O E L}$ | $V_{C C}$ |
| B4 | X2 | F5 | H1 | Y13/P13 | F4 | K9 | P30 | $\mathrm{v}_{\mathrm{cc} / 2}$ | C11 | X15 | F8 |
| A4 | X1 | F6 | J2 | Y14/P14 | F8 | L9 | P31 | $\mathrm{V}_{\mathrm{cc} / 2}$ | B10 | X14 | F9 |
| B3 | xo | F7 | J1 | Y15/P15 | F9 | K10 | P32 | $\mathrm{v}_{\mathrm{CC} / 2}$ | A10 | X13 | F10 |
| A3 | YO/PO | F8 | K2 | P16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | P33 | $\mathrm{v}_{\mathrm{CC} / 2}$ | B9 | X12 | F11 |
| B2 | Y1/P1 | F9 | L2 | P17 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J10 | P34 | $\mathrm{v}_{\mathrm{CC} / 2}$ | A9 | X11 | F12 |
| B1 | Y2/P2 | F10 | K3 | P18 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J11 | CLKP | FO | B8 | X10 | F13 |
| C2 | Y3/P3 | F11 | L3 | P19 | $\mathrm{v}_{\mathrm{CC} / 2}$ | H10 | $\overline{O E M}$ | GND | A8 | X9 | F14 |
| C1 | Y4/P4 | F12 | K4 | P20 | $\mathrm{v}_{\mathrm{CC} / 2}$ | H11 | PREL | F6 | B7 | X8 | F15 |
| D2 | Y5/P5 | F13 | L4 | P21 | $\mathrm{V}_{\mathrm{CC}} / 2$ | G10 | $\overline{\text { OEX }}$ | GND | A7 | X7 | F7 |
| D1 | Y6/P6 | F14 | K5 | P22 | $\mathrm{v}_{\mathrm{CC}} / 2$ | G11 | TC | F5 | A2 | N.C. | N.C. |
| E2 | Y7/P7 | F15 | L5 | P23 | $\mathrm{V}_{\mathrm{CC}} / 2$ | F10 | $V_{C C}$ | $V_{\text {cc }}$ | K1 | N.C. | N.C. |
| E1 | GND | GND | K6 | P24 | $\mathrm{v}_{\mathrm{cc} / 2}$ | F11 | CLKY | Fo | L10 | N.C. | N.C. |
| F2 | Y8/P8 | F1 | L6 | P25 | $\mathrm{v}_{\mathrm{cc}} / 2$ | E10 | CLKX | FO | B11 | N.C. | N.C. |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND
2. $F O=100 \mathrm{kHz}, F_{1}=F 0 / 2, F_{2}=F 1 / 2$, . $10 \%$
3. $V_{I H}=V_{C C}-1 V \pm 0.5 V(M i n), V_{I L}=0.8 V$ (Max)
4. $47 \mathrm{k} \Omega$ load resistors used on all pins except $V_{C C}$ and GND (Pin-Grid identifiers F10, G10, G11 and H11)

## Die Characteristics

DIE DIMENSIONS:
$184 \times 176 \times 19 \pm 1 \mathrm{mils}$

## METALLIZATION:

Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$

## GLASSIVATION:

Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSTTY: $0.9 \times 10^{5} \mathrm{Acm}^{2}$
Metallization Mask Layout


## Features

- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (35ns) Clocked Multiply Time
- Low Power Operation:
- $I_{\text {ccsB }}=500 \mu \mathrm{~A}$ Maximum
- $I_{\text {ccop }}=7.0 \mathrm{~mA}$ Maximum at $\mathbf{1 M H z}$
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- HMU16 is Compatible with the AM29516, LMU16, IDT7216 and the CY7C516
- HMU17 is Compatible with the AM29517, LMU17, IDT7217 and the CY7C517
- TTL Compatible Inputs/Outputs
- Three-State Outputs


## Applications

- Fast Fourier Transform Analysis
- Digital Filtering
- Graphic Display Systems
- Image Processing
- Radar and Sonar
- Speech Synthesis and Recognition


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HMU16JC-35 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMU16JC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMU16GC-35 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMU16GC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMU17JC-35 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMU17JC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HMU17GC-35 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMU17GC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HMU16 and HMU17 are high speed, low power CMOS $16 \times 16$-bit multipliers ideal for fast, real time digital signal processing applications.

The $X$ and $Y$ operands along with their mode controls (TCX and TCY) have 17 -bit input registers. The mode controls independently specify the operands as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.

Two 16-bit output registers are provided to hold the most and least significant halves of the result (MSP and LSP). For asynchronous output these registers may be made transparent through the use of the feedthrough control (FT).

Additional inputs are provided for format adjustment and rounding. The format adjust control (FA) allows the user to select either a left shifted 31-bit product or a full 32-bit product, whereas the round control (RND) provides the capability of rounding the most significant portion of the result.

The HMU16 has independent clocks (CLKX, CLKY, CLKL, CLKM) associated with each of these registers to maximize throughput and simplify bus interfacing. The HMU17 has only a single clock input (CLK), but makes use of three register enables ( $\overline{\text { ENX, ENY }}$ and ENP). The ENX and ENY inputs control the X and Y input registers, while ENP controls both the MSP and LSP output registers. This configuration facilitates the use of the HMU17 for microprogrammed systems.

The two halves of the product may be routed to a single 16-bit three-state output port via a multiplexer, and in addition, the LSP is connected to the Y -input port through a separate three-state buffer.

All outputs of the HMU16 and HMU17 multipliers also offer three-state control for multiplexing results onto multiuse busses.

## Package Pinouts

CERAMIC 68 PIN GRID ARRAY (PGA)
TOP VIEW


68 PIN PLASTIC LEADED CHIP CARRIER (PLCC)
TOP VIEW


## Functional Block Diagram



HMU17


## Pin Description

| SYMBOL | PLCC PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 1,68 |  | $\mathrm{V}_{\mathrm{CC}}$. The +5 V power supply pins. $\mathrm{A} 0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and $G N D$ pins is recommended. |
| GND | 2,3 |  | GND. The device ground. |
| X0-X15 | 47-59, 61-63 | I | X-Input Data. These 16 data inputs provide the multiplicand which may be in two's complement or unsigned magnitude format. |
| $\begin{aligned} & \text { YO-Y15/ } \\ & \text { PO-P15 } \end{aligned}$ | 27-42 | 1/0 | Y-Input/LSP Output Data. This 16-Bit port is used to provide the multiplier which may be in two's complement or unsigned magnitude format. It may also be used for output of the Least Significant Product (LSP). |
| $\begin{gathered} \text { P16-P31/ } \\ \text { PO-P15 } \end{gathered}$ | 10-25 | 0 | Output Data. This 16-Bit port may provide either the MSP (P16-31) or the LSP (PO-15). |
| TCY, TCX | 66,67 | 1 | Two's Complement Control. Input data is interpreted as two's complement when this control is HIGH. A LOW indicates the data is to be interpreted as unsigned magnitude format. |
| FT | 5 | 1 | Feedthrough Control. When this control is HIGH, both the MSP and LSP registers are transparent. When LOW, the registers are latched by their associated clock signals. |
| FA | 6 |  | Format Adjust Control. A full 32-bit product is selected when this control line is HIGH. A LOW on this control line selects a left shifted 31 -bit product with the sign bit replicated in the LSP. This control is normally HIGH except for certain two's complement integer and fractional applications. |
| RND | 65 | 1 | Round Control. When this control is HIGH, a one is added to the Most Significant Bit (MSB) of the LSP. This position is dependent on the FA contro; $\mathrm{FA}=\mathrm{HIGH}$ indicates RND adds to the 2-15 bit (P15), and FA = LOW indicates RND adds to the 2-16 bit (P14). |
| $\overline{\text { MSPSEL }}$ | 4 | 1 | Output Multiplexer Control. When this control is LOW, the MSP is available for output at the dedicated output port, and the LSP is available at the $Y$-input/LSP output port. When MSPSEL is HIGH, the LSP is available at both ports and the MSP is not available for output. |
| $\overline{\mathrm{OEL}}$ | 46 | 1 | Y-In/PO-15 Output Port Three-state Control. When $\overline{\text { OEL }}$ is HIGH, the output drivers are in the high impedance state. This state is required for $Y$-data input. When $\overline{O E L}$ is LOW, the port is enabled for LSP output. |
| $\overline{O E P}$ | 7 | I | P16-31/P0-15 Output Port Three-state Control. A LOW on this control line enables the output port. When $\overline{O E P}$ is HIGH, the output drivers are in the high impedance state. |

The following Pin Descriptions apply to the HMU16 only.

| CLKX | 64 | 1 | X-Register Clock. The rising edge of this clock loads the X -data input register along with the TCX and RND registers. |
| :---: | :---: | :---: | :---: |
| CLKY | 44 | I | Y -Register Clock. The rising edge of this clock loads the Y -data input register along with the TCY and RND registers. |
| CLKM | 8 | 1 | MSP Register Clock. The rising edge of CLKM loads the most significant product (MSP) register. |
| CLKL | 45 | 1 | LSP Register Clock. The rising edge of CLKL loads the least significant product (LSP) register. |
| The following Pin Descriptions apply to the HMU17 only. |  |  |  |
| CLK | 45 | 1 | Clock. The rising edge of this clock will load all enabled registers. |
| $\overline{\text { ENX }}$ | 64 | 1 | X-Register Enable. When ENX is LOW, the X-register is enabled; X-input data and TCX will be latched at the rising edge of CLK. When ENX is high, the X-register is in a hold mode. |
| $\overline{\text { ENY }}$ | 44 | 1 | $Y$-Register Enable. $\overline{\text { ENY }}$ enables the Y -register. (See $\overline{\mathrm{ENX}}$ ). |
| $\overline{\text { ENP }}$ | 8 | 1 | Product Register Enable. $\overline{\mathrm{ENP}}$ enables the product register. Both the MSP and LSP sections are enabled by ENP. (See ENX). |

## Functional Description

The HMU16/HMU17 are high speed $16 \times 16$-bit multipliers designed to perform very fast multiplication of two 16-bit binary numbers. The two 16-bit operands ( X and Y ) may be independently specified as either two's complement or unsigned magnitude format by the two's complement controls (TCX and TCY). When either of these control lines is LOW, the respective operand is treated as an unsigned 16-bit value; and when it is HIGH, the operand is treated as a signed value represented in two's complement format. The operands along with their respective controls are latched at the rising edge of the associated clock signal. The HMU16 accomplishes this through the use of independent clock inputs for each of the input registers (CLKX and CLKY), while the HMU17 utilizes a single clock signal (CLK) along with the $X$ and $Y$ register enable inputs (ENX and ENY).

Input controls are also provided for rounding and format adjustment of the 32-bit product. The Round input (RND) is provided to accomodate rounding of the most significant portion of the product by adding one to the Most Significant Bit (MSB) of the LSP register. The position of the MSB is dependent on the state of the Format Adjust Control (See Pin Descriptions and Multiplier Input/Output Format Tables). The Round input is latched into the RND register whenever either of the input registers is clocked. The Format Adjust control ( $\overline{\mathrm{FA}})$ allows the product output to be formatted. When the $\overline{F A}$ control is HIGH, a full 32-bit product is output; and when $\overline{F A}$ is LOW, a left-shifted 31-bit product is output with the sign bit replicated in bit position 15 of the LSP. The $\overline{F A}$ control must be HIGH for unsigned magnitude, and mixed mode multiplication
operations. It may be LOW for certain two's complement integer and fractional operations only (See Multiplier Input/ Output Formats Table).

The HMU16/HMU17 multipliers are equipped with two 16-bit output registers (MSP and LSP) which are provided to hold the most and least significant portions of the resultant product respectively. The HMU16 uses independent clocks (CLKM and CLKL) for latching the two output registers, while the HMU17 uses a single clock input (CLK) along with the Product Latch Enable (ENP). The MSP and LSP registers may also be made transparent for asynchronous output through the use of the Feedthrough control (FT).

There are two output configurations which may be selected when using the HMU16/HMU17 multipliers. The first configuration allows the simultaneous access of the most and least significant halves of the product. When the MSPSEL input is LOW, the Most Significant Product will be available at the dedicated output port (P16-31/P0-15). The Least Significant Product is simultaneously available at the bi-directional port shared with the Y -inputs (YO-15/PO-15) through the use of the LSP output enable (OEL). The other output configuration involves multiplexing the MSP and LSP registers onto the dedicated output port through the use of the MSPSEL control. When the MSPSEL control is LOW, the Most Significant Product will be available at the dedicated output port; and when MSPSEL is HIGH, the Least Significant Product will be available at this port. This configuration allows access of the entire 32-bit product by a 16-bit wide system bus.

## Multiplier Input/Output Formats Table

FRACTIONAL TWO'S COMPLEMENT NOTATION


* In this format an overflow occurs in the attempted multiplication of the two's complement number $1,000 \ldots 0$ with $1,000 \ldots 0$ yielding an erroneous product of -1 in the fraction case and $-2^{30}$ in the integer case.

FRACTIONAL UNSIGNED MAGNITUDE NOTATION


FRACTIONAL MIXED MODE NOTATION

```
lol
```


## Multiplier Input/Output Formats Tab/e (Continued)

INTEGER TWO'S COMPLEMENT NOTATION

integer mixed mode notation


## Absolute Maximum Ratings



## Operating Conditions


D.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| VIL | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.6 | - | V | $\mathrm{l}^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | - | 0.4 | V | $\mathrm{l}^{\mathrm{OL}}=+4.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 10 | Output or I/O Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| ${ }^{\prime} \mathrm{Ccss}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V} \\ & \text { Outputs Open } \end{aligned}$ |
| ${ }^{\text {I CCOP }}$ | Operating Power Supply Current | - | 7.0 | mA | $\begin{aligned} & V_{1}=V_{C C} \text { or GND, } V_{C C}=5.25 \mathrm{~V} \\ & f=1 \mathrm{MHz}(\text { Note 1) } \end{aligned}$ |

Capacitance $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$, Note 2)

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 15 | pF | Frequency $=1 \mathrm{MHz}$. <br> All measurements referenced <br> to device Ground. |
| $C_{\text {OUT }}$ | Output Capacitance | 10 | pF |  |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance | 10 | pF |  |

## NOTES:

1. Operating Supply Current is proportional to frequency, Typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/ design changes.
A.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 3)

| SYMBOL | PARAMETER | HMU16/HMU17-35 |  | HMU16/HMU17-45 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| TMUC | Unclocked Multiply Time | - | 55 | - | 70 | ns |  |
| TMC | Clocked Multiply Time | - | 35 | - | 45 | ns |  |
| Ts | X, Y, RND Setup Time | 15 | - | 18 | - | ns |  |
| $\mathrm{T}_{\mathrm{H}}$ | X, Y, RND Hold Time | 2 | - | 2 | - | ns |  |
| TPWH | Clock Pulse Width High | 10 | - | 15 | - | ns |  |
| TPWL | Clock Pulse Width Low | 10 | - | 15 | - | ns |  |
| TPDSEL | MSPSEL to Product Out | - | 22 | - | 25 | ns |  |
| TPDP | Output Clock to P | - | 22 | - | 25 | ns |  |
| TPDY | Output Clock to Y | - | 22 | - | 25 | ns |  |
| Tena | 3-State Enable Time | - | 22 | - | 25 | ns | Note 1 |
| TDIS | 3-State Disable Time | - | 22 | - | 25 | ns |  |
| TSE | Clock Enable Setup Time (HMU17 only) | 15 | - | 15 | - | ns |  |
| THE | Clock Enable Hold Time (HMU17 only) | 2 | - | 2 | - | ns |  |
| $\mathrm{T}_{\mathrm{HCL}}$ | Clock Low Hold Time CLKXY Relative to CLKML (HMU16 only) | 0 | - | 0 | - | ns | Note 2 |
| TR | Output Rise Time | - | 8 | - | 8 | ns | From 0.8 V to 2.0 V |
| $\mathrm{T}_{\mathrm{F}}$ | Output Fall Time | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading specified in A.C. Test Circuit, $V_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{1}=40 \mathrm{pF}$
2. To ensure the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.
A.C. Test Circuit


* Includes Stray and Jig Capacitance
A.C. Testing Input, Output Waveforms

A.C. Testing: All parameters tested as per test circuit. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{N}$.


## Timing Diagram



THREE STATE CONTROL


HMU16/883

## $16 \times 16$-Bit CMOS Parallel Multiplier

## Features

- This Circuit is Processed In Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (45ns) Clocked Multiply Time
- Low Power CMOS Operation
- $I_{\text {ccsB }}=500 \mu A$ Maximum
- $\mathrm{I}_{\text {ccop }}=7.0 \mathrm{~mA}$ Maximum at 1 MHz
- HMU16/883 is Compatible with the AM29516, LMU16, IDT7216, and the CY7C516
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- TTL Compatible Inputs/Outputs
- Three-State Outputs


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HMU16GM-45/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMU16GM-60/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HMU16/883 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier ideal for fast, real time digital signal processing applications. The 16-bit $X$ and $Y$ operands may be independently specified as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.
Additional inputs are provided to accommodate format adjustment and rounding of the 32-bit product. The Format Adjust control allows the user to select a 31-bit product with the sign bit replicated in the LSP. The Round control provides for rounding the most significant portion of the result by adding one to the most significant bit of the LSP.

Two 16-bit output registers (MSP and LSP) are provided to hold the most and least significant portions of the result, respectively. These registers may be made transparent for asynchronous operation through the use of the feedthrough control (FT). The two halves of the product may be routed to a single 16-bit three-state output port via the output multiplexer control, and in addition, the LSP is connected to the Y-input port through a separate three-state buffer.

The HMU16/883 utilizes independent clock signals (CLKX, CLKY, CLKL, CLKM) to latch the input operands and output product registers. This configuration maximizes throughput and simplifies bus interfacing. All outputs of the HMU16/883 also offer three-state control for multiplexing onto multiuse system busses.

## Functional Diagram



## Absolute Maximum Ratings



ESD Classification .............................................. . . . . Class 1
CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range $. \ldots \ldots \ldots . . . . . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. HMU16/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $V_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Output HIGH Voltage | $\mathrm{VOH}^{\text {O }}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voitage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { (Note 1) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $V_{I N}=V_{C C}$ or GND, $V_{C C}=5.5 \mathrm{~V}$, Outputs Open | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {a ccop }}$ | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \tau \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.

## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package . | $42.69^{\circ} \mathrm{C} / \mathrm{W}$ | $10.0{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
|  |  |  |
| Gate Count |  | 00 Gates |

TABLE 2. HMU16/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Unclocked Multiply Time | TMUC |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | - | 90 | ns |
| Clocked Multiply Time | $\mathrm{T}_{\mathrm{MC}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 45 | - | 60 | ns |
| X, Y, RND Setup Time | Ts |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 20 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock LOW Pulse Width | TPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| MSPSEL to Product Out | TPDSEL |  | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to P | TPDP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to Y | TPDY |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Low Hold Time CLKXY Relative to CLKML | THCL | (Note 3) | $9,10,11$ | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |

1. $A C$ Testing as follows: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Input levels $O \mathrm{~V}$ and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=$ $2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, R_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
3. To ensure the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.

TABLE 3. HMU16/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{CIN}_{1}$ | $V_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All Measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | Cout |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| 1/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| X, Y, RND Hold Time | $\mathrm{T}_{\mathrm{H}}$ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| 3-State Disable Time | TDIS |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |

NOTES: 1. The parameters listed in table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Guaranteed, but not $100 \%$ tested.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
4. Loading is as specified in the test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}$, $\mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X4 | F6 | F1 | Y9/P9 | F11 | K7 | P10/P26 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E11 | RND | F1 |
| A6 | X3 | F5 | G2 | Y10/P10 | F12 | L7 | P11/P27 | $\mathrm{v}_{\mathrm{CC}} / 2$ | D10 | CLKX | FO |
| B5 | X2 | F4 | G1 | Y11/P11 | F13 | K8 | P12/P28 | $\mathrm{v}_{\mathrm{CC} / 2}$ | D11 | X15 | F3 |
| A5 | X1 | F3 | H2 | Y12/P12 | F14 | L8 | P13/P29 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C10 | X14 | F2 |
| B4 | xo | F2 | H1 | Y13/P13 | F15 | K9 | P14/P30 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C11 | X13 | F15 |
| A4 | OEL | $V_{C C}$ | J2 | Y14/P14 | F4 | L9 | P15/P31 | $\mathrm{v}_{\mathrm{CC}} / 2$ | B10 | X12 | F14 |
| B3 | CLKL | FO | J1 | Y15/P15 | F5 | K10 | CLKM | FO | A10 | X11 | F13 |
| A3 | CLKY | FO | K2 | P0/P16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | $\overline{\mathrm{OEP}}$ | F1 | B9 | X10 | F12 |
| B2 | YO/PO | F2 | L2 | P1/P17 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J10 | $\overline{F A}$ | F14 | A9 | X9 | F11 |
| B1 | Y1/P1 | F3 | K3 | P2/P18 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J11 | FT | F15 | B8 | X8 | F10 |
| C2 | Y2/P2 | F4 | L3 | P3/P19 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H10 | MSPSEL | F14 | A8 | X7 | F9 |
| C1 | Y3/P3 | F5 | K4 | P4/P20 | $\mathrm{V}_{\mathrm{CC}} / 2$ | H11 | GND | GND | B7 | X6 | F8 |
| D2 | Y4/P4 | F6 | L4 | P5/P21 | $\mathrm{V}_{\mathrm{CC} / 2}$ | G10 | GND | GND | A7 | X5 | F7 |
| D1 | Y5/P5 | F7 | K5 | P6/P22 | $\mathrm{V}_{\mathrm{CC} / 2}$ | G11 | $V_{C C}$ | $\mathrm{V}_{\mathrm{CC}}$ | A2 | N.C. | NONE |
| E2 | Y6/P6 | F8 | L5 | P7/P23 | $\mathrm{V}_{\mathrm{Cc} / 2}$ | F10 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {CC }}$ | K1 | N.C. | NONE |
| E1 | Y7/P7 | F9 | K6 | P8/P24 | $\mathrm{v}_{\mathrm{CC}} / 2$ | F11 | TCY | F15 | L10 | N.C. | NONE |
| F2 | Y8/P8 | F10 | L6 | P9/P25 | $\mathrm{v}_{\mathrm{CC} / 2}$ | E10 | TCX | F15 | B11 | N.C. | NONE |

notes:

1. $V_{C C}=5.0 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND
2. $F 0=100 \mathrm{kHz}, F_{1}=F 0 / 2, F_{2}=F_{1} / 2$
3. $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-1 \mathrm{~V} \pm 0.5 \mathrm{~V}(\mathrm{Min}), \mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ (Max)
4. $47 \mathrm{k} \Omega$ load resistors used on all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND (Pin-Grid identifiers F10, G10, G11 and H11).

## Die Characteristics

DIE DIMENSIONS:
$179 \times 169 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$
Metallization Mask Layout
HMU16/883


HMU17/883

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (45ns) Clocked Multiply Time
- Low Power CMOS Operation:
- $I_{\text {ccse }}=500 \mu \mathrm{~A}$ Maximum
- $l_{\text {ccop }}=7.0 \mathrm{~mA}$ Maximum at $1 \mathbf{M H z}$
- HMU17/883 is Compatible with the AM29517, LMU17, IDT7217, and the CY7C517
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- TTL Compatible Inputs/Outputs
- Three-State Outputs


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HMU17GM- $45 / 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HMU17GM- $60 / 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HMU17/883 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier ideal for fast, real time digital signal processing applications. The 16 -bit $X$ and $Y$ operands may be independently specified as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.

Additional inputs are provided to accommodate format adjustment and rounding of the 32 -bit product. The Format Adjust control allows the user the option of selecting a 31-bit product with the sign bit replicated LSP. The Round control is provided to accommodate rounding of the most significant portion of the result. This is accomplished by adding one to the most significant bit of the LSP.

Two 16-bit output registers (MSP and LSP) are provided to hold the most and least significant portions of the result, respectively. These registers may be made transparent for asynchronous operation through the use of the feedthrough control (FT). The two halves of the product may be routed to a single 16 -bit threestate output port via the output multiplexer control, and in addition, the LSP is connected to the Y-input port through a separate three-state buffer.

The HMU17/883 utilizes a single clock signal (CLK) along with three register enables (ENX, ENY, and ENP) to latch the input operands and the output product registers. The ENX and ENY inputs enable the $X$ and $Y$ input registers, while ENP enables both the LSP and MSP output registers. This configuration facilitates the use of the HMU17/883 for micro-programmed systems.

All outputs of the HMU17/883 also offer three-state control for multiplexing onto multiuse system busses.

## Functional Diagram



| Absolute Maximum Ratings | Reliability information |
| :---: | :---: |
| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V | Thermal Resistance $\quad \theta_{\text {ja }} \quad \theta_{\mathrm{jc}}$ |
| Input or Output Voltage Applied ........ GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ | Ceramic PGA Package . . . . . . . . . . . $42.69^{\circ} \mathrm{C} / \mathrm{W} \quad 10.0^{\circ} \mathrm{C} / \mathrm{W}$ |
| Storage Temperature Range . . . . . . . . . . . . . . . $-656^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Maximum Package Power Dissipation at $+125{ }^{\circ} \mathrm{C}$ |
| Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ | Ceramic PGA Package . . . . . . . . . . . . . . . . . . . . . . . . 1.17 Watt |
| Lead Temperature (Soldering 10 sec ) . . . . . . . . . . . . . . . . . $300^{\circ} \mathrm{C}$ | Gate Count . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4500 Gates |
| ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1 |  |
| CAUTION: Stresses above those listed in "Absolute Maximum Ratings" ma of the device at these or any other conditions above those indicated in the | e permanent damage to the device. This is a stress only rating and operation tional sections of this specification is not implied. |

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HMU16/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | Limits |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $V^{\text {IH }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or } \mathrm{GND} \\ & V_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | I'ccsb | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND, <br> $V_{C C}=5.5 \mathrm{~V}$, Outputs <br> Open | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power <br> Supply Current | ICCOP | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (Clock Inputs) $=3.0, \mathrm{~V}_{\mathrm{IH}}$ (All other inputs) $=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 2. HMU17/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Unclocked Multiply Time | $\mathrm{T}_{\text {MUC }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | - | 90 | ns |
| Clocked Multiply Time | $\mathrm{T}_{\mathrm{MC}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 45 | - | 60 | ns |
| X, Y, RND Setup Time | Ts |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 20 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock LOW Pulse Width | TPWL |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| MSPSEL to Product Out | TPDSEL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to P | TPDP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to $Y$ | TPDY |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns . |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Enable Setup | TSE |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |

NOTES:

1. $A C$ Testing as follows: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Input levels $O \mathrm{~V}$ and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=$
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. $2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 3. HMU17/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{CIN}_{1}$ | $v_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All Measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| I/O Capacitance | $\mathrm{C}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| X, Y, RND Hold Time | $\mathrm{TH}_{\mathrm{H}}$ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| 3-State Disable Time | TDIS |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Enable Hold Time | THE |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |
| Output Fall Time | $T_{F}$ | From 2.0 V to 0.8 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Guaranteed, but not $100 \%$ tested.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
4. Loading is as specified in the test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

HMU17/883
Burn-In Circuit


| PGA PIN | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | PGA PIN | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X4 | F6 | F1 | Y9/P9 | F11 | K7 | P10/P26 | $V_{\text {cc } / 2}$ | E11 | RND | F1 |
| A6 | X3 | F5 | G2 | Y10/P10 | F12 | L7 | P11/P27 | $\mathrm{V}_{\mathrm{cc}} / 2$ | D10 | ENX | FO |
| B5 | X2 | F4 | G1 | Y11/P11 | F13 | K8 | P12/P28 | $v_{\text {cc } / 2}$ | 011 | X15 | F3 |
| A5 | X 1 | F3 | H2 | Y12/P12 | F14 | L8 | P13/P29 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C10 | X14 | F2 |
| B4 | X0 | F2 | H1 | Y13/P13 | F15 | K9 | P14/P30 | $\mathrm{V}_{\mathrm{Cc}} / 2$ | C11 | X13 | F15 |
| A4 | $\overline{O E L}$ | VCC | J2 | Y14/P14 | F4 | L9 | P15/P31 | $v_{\text {ccl/ }}$ | B10 | X12 | F14 |
| B3 | CLK | Fo | J1 | Y15/P15 | F5 | K10 | ENP | FO | A10 | X11 | F13 |
| A3 | ENY | FO | K2 | PO/P16 | $\mathrm{V}_{\mathrm{cc} / 2}$ | K11 | $\overline{\mathrm{OEP}}$ | F1 | B9 | X10 | F12 |
| B2 | YO/PO | F2 | L2 | P1/P17 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J10 | $\overline{\mathrm{FA}}$ | F14 | A9 | X9 | F11 |
| B1 | Y1/P1 | F3 | K3 | P2/P18 | $\mathrm{v}_{\mathrm{CC} / 2}$ | $J 11$ | FT | F15 | B8 | x8 | F10 |
| C2 | Y2/P2 | F4 | L3 | P3/P19 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H10 | MSPSEL | F14 | A8 | X7 | F9 |
| C1 | Y3/P3 | F5 | K4 | P4/P20 | $\mathrm{v}_{\mathrm{CC}} / 2$ | H11 | GND | GND | B7 | X6 | F8 |
| D2 | Y4/P4 | F6 | L4 | P5/P21 | $v_{\mathrm{cc}} / 2$ | G10 | GND | GND | A7 | X5 | F7 |
| D1 | Y5/P5 | F7 | K5 | P6/P22 | $\mathrm{v}_{\mathrm{CC}} / 2$ | G11 | $v_{C C}$ | $\mathrm{v}_{\mathrm{CC}}$ | A2 | N.C. | NONE |
| E2 | Y6/P6 | F8 | L5 | P7/P23 | $\mathrm{v}_{\mathrm{cc} / 2}$ | F10 | $V_{\text {cc }}$ | $V_{\text {cc }}$ | K1 | N.C. | NONE |
| E1 | Y7/P7 | F9 | K6 | P8/P24 | $\mathrm{v}_{\mathrm{cc} / 2}$ | F11 | TCY | F15 | L10 | N.C. | NONE |
| F2 | Y8/P8 | F10 | L6 | P9/P25 | $\mathrm{v}_{\mathrm{CC}} / 2$ | E10 | TCX | F15 | B11 | N.C. | NONE |

## NOTES:

1. $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND.
2. $F_{O}=100 \mathrm{kHz}, F_{1}=F O / 2, F 2=F 1 / 2, \ldots \ldots$.
3. $V_{I H}=V_{C C}-1 V \pm 0.5 V(M i n), V_{I L}=0.8 V$ (Max).
4. $47 \mathrm{k} \Omega$ load resistors used on all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND (Pin-Grid identifiers F10, G10, G11 and H11).

## Die Characteristics

DIE DIMENSIONS:
$179 \times 169 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al or Si-Al-Cu
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} \mathrm{~cm}^{2}$
Metallization Mask Layout
HMU17/883

(56) $\times 13$
(55) $\times 14$
(54) $\times 15$
(53) CLKX (ENX) (52) RND (51) TCX (50) TCY
(49) VCC
(48) $V_{C C}$
(47) GND
(46) GND
(45) MSPSEL
(44) FT
(43) $\overline{\mathrm{FA}}$
(42) $\overline{D E P}$
(41) CLKM (END)
(25) P0, P18
(26) P1, P17
(27) P2, P18
(28) P3, P19
(29) P4, P20
(30) P5, P21
(31) P8, P22
(32) P7, P23
(33) P8, P24
(34) P9, P25
(35) P10, P26
(36) P11, P27
(37) P12, P28
(38) P13, P20
(39) P14, P30
(40) P15, P31

## ONE DIMENSIONAL FILTERS

## PAGE

## ONE DIMENSION FILTER DATA SHEETS

| HSP43124 | Serial VO Filter. | 3-3 |
| :---: | :---: | :---: |
| HSP43168 | Dual FIR Filter. | 3-18 |
| HSP43168/883 | Dual FIR Filter. | 3-35 |
| HSP43216 | Halfband Filter . | 3-43 |
| HSP43220 | Decimating Digital Filter | 3-60 |
| HSP43220/883 | Decimating Digital Filter | 3-83 |
| HSP43481 | Digital Filter . | 3-90 |
| HSP43481/883 | Digital Filter . | 3-105 |
| HSP43881 | Digital Filter. | 3-110 |
| HSP43881/883 | Digital Filter. | 3-125 |
| HSP43891 | Digital Filter. | 3-131 |
| HSP43891/883 | Digital Filter. | 3-147 |

NOTE: Bold Type Designates a New Product from Harris.

## Features

- 45MHz Clock Rate
- 256 Tap Programmable FIR Filter
- 24-Bit Data, 32-Bit Coefficients
- Cascade of up to 5 Half Band Filters
- Decimation from 1 to 256
- Two Pin Interface for Down Conversion by F $\mathbf{F}_{\mathbf{S}} / 4$
- Multiplier for Mixing or Scaling Input with an External Source
- Serial VO Compatible with Most DSP Microprocessors


## Applications

- Low Cost FIR Filter
- Filter Co-Processor
- Digital Tuner


## Ordering Information

| PART <br> NUMBER | TEMPERATURE <br> RANGE | PACKAGE TYPE |
| :---: | :---: | :--- |
| HSP43124PC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead Plastic DIP |
| HSP $43124 \mathrm{SC}-45$ | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead SOIC |

## Description

The Serial I/O Filter is a high performance filter engine that is ideal for off loading the burden of filter processing from a DSP microprocessor. It supports a variety of multistage filter configurations based on a user programmable filter and fixed coefficient halfband filters. These configurations include a programmable FIR filter of up to 256 taps, a cascade of from one to five halfband filters, or a cascade of halfband filters followed by a programmable FIR. The half band filters each decimate by a factor of two, and the FIR filter decimates from one to eight. When all six filters are selected, a maximum decimation of 256 is provided.

For digital tuning applications, a separate multiplier is provided which allows the incoming data stream to be multiplied, or mixed, by a user supplied mix factor. A two pin interface is provided for serially loading the mix factor from an external source or selecting the mix factor from an onboard ROM. The on-board ROM contains samples of a sinusoid capable of spectrally shifting the input data by one quarter of the sample rate, $\mathrm{F}_{\mathrm{S}} / 4$. This allows the chip to function as a digital down converter when the filter stages are configured as a low-pass filter.
The serial interface for input and output data is compatible with the serial ports of common DSP microprocessors. Coefficients and configuration data are loaded over a bidirectional eight bit interface. This product is available in 28 pin DIP and SOIC packages.

## Block Diagram



## Pinout

|  |  |  |
| :---: | :---: | :---: |
| SCLK 1 | 28 | DIN |
| SYNCIN 2 | 27 | DOUT |
| GND 3 | 26 | Syncout |
| MXIN 4 | 25 | CLKKOUT |
| Syncmx 5 | 24 | $\mathrm{v}_{\mathrm{cc}}$ |
| FSYNC\# 6 | 23 | C7 |
| $V_{c c} 7$ | 22 | C6 |
| FCLK 8 | 21 | C5 |
| WR" 9 | 20 | C4 |
| RD* 10 | 19 | GND |
| A0 11 | 18 | C3 |
| A1 12 | 17 | C2 |
| A2 13 | 16 | C1 |
| $\mathrm{v}_{\mathrm{cc}} 14$ | 15 | co |

Pin Description

| NAME | PDIP, SOIC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 7, 14, 24 | - | +5V Power Supply |
| GND | 3, 19 | - | Ground |
| DIN | 28 | 1 | Serial Data Input. The bit value present on this input is sampled on the rising edge of SCLK. A "HIGH" on this input represents a "1", and a low on this input represents " 0 ". The word format and operation of serial interface are contained in the Data Input Section. |
| SYNCIN | 2 | 1 | Data Sync. The HSP43124 is synchronized to the beginning of a new data word on DIN when SCLK samples SYNCIN "HIGH" one SCLK before the first bit of the new word. Note: SYNCIN should not maintain a "HIGH" state for longer than one SCLK cycle. |
| SCLK | 1 | 1 | Serial Input CLK. The rising edge of SCLK clocks data on DIN and MXIN into the part. The following signals are synchronous to this clock: DIN, SYNCIN, MXIN, SYNCMX. |
| MXIN | 4 | 1 | Mix Factor Input. MXIN is the serial input for the mix factor. It is sampled on the rising edge of SCLK. A "HIGH" on this input represents a "1", and a low on this input represents "0". Also used to specify the Weaver Modulator ROM output. Details on word format and operation are contained in the Mix Factor Section. |
| SYNCMX | 5 | 1 | Mix Factor Sync. The HSP43124 is synchronized to the beginning of a serially input mix factor when SCLK samples SYNCMX "HIGH" one SCLK before the first bit of the new mix factor. Note: SYNCMX should only pulse "HIGH" for one SCLK cycle. Also used to specify Weaver Modulator ROM output. |
| FCLK | 8 | 1 | Filter Clock. The filter clock determines the processing speed of the Filter Compute Engine. Clock rate requirements on FCLK for particular filter configurations is discussed in the Filter Compute Engine Section. This clock may be asynchronous to the serial input clock (SCLK). FSYNC\# is synchronous to this clock. |
| FSYNC\# | 6 | 1 | Filter Sync. This input, when sampled low by the rising edge of FCLK, resets the filter compute engine so that the data sample following the next SYNCIN cycle is the first data sample into the filter structure. If a data stream is currently being input, the data is "canceled" and the DIN pin is ignored until the next SYNCIN cycle occurs. |
| WR\# | 9 | 1 | Write. The falling edge of WR\# loads data present on $\mathrm{CO}-7$ into the configuration or coefficient register specified by the address on A0-2. The WR\# signal is asynchronous to all other clocks. Note: WR\# should not be low when RD\# is low. |
| RD\# | 10 | 1 | Read. The falling edge of RD\# accesses the control registers or coefficient RAM addressed by $\mathrm{AO}-2$ and places the contents of that memory location on $\mathrm{C0} 0$. . When RD\# returns "HIGH" the C0-7 bus functions as an input bus. The RD\# pin is asynchronous to all other clocks. Note: RD\# should not be low when WR\# is low. |
| A0-2 | 11, 12, 13 | 1 | Address Bus. The A0-2 inputs are decoded on the falling edge of both RD\# and WR\#. Table 1 shows the address map for the control registers. |
| C0-7 | $\begin{gathered} 15,16,17,18,20 \\ 21,22,23 \end{gathered}$ | 1/0 | Control and Coefficient bus. This bi-directional bus is used to access the control registers and coefficient RAM. |
| CLKKOUT | 25 | 0 | Output Clock. Programmable bit clock for serial output. Note: assertion of FILTSYNC\# initializes OCLK to a high state. |
| SYNCOUT | 26 | 0 | Output Data Sync. SYNYOUT is asserted HIGH for one OCLK cycle before the first bit of a new output sample is available on DOUT. |
| DOUT | 27 | 0 | Serial Data Output. The bit stream is synchronous to the rising edge of OCLK. See the Serial Output Formatter section for additional details. |



FIGURE 1. SERIAL FILTER BLOCK DIAGRAM

## Functional Description

The HSP43124 is a high performance digital filter designed to process a data stream which is input serially. A second serial input is provided for inputting mix factors which are multiplied by the input samples as shown in Figure 1. The result of this operation is passed to the Filter Compute Engine for processing.

The Filter Compute Engine centers around a single multiply/ accumulator (MAC). The MAC performs the sum-of-products required by a particular filter configuration. The processing rate of the MAC is determined by the filter clock, FCLK. Increasing FCLK relative to the input sample rate increases the length of filter that can be realized.
The filtered results are passed to the Output Formatter where they are rounded or truncated to a user defined bit width. The Output Formatter then generates the timing and synchronization signals required to serially transmit the data to an external device.

## Filter Configuration

The HSP43124 is configured for operation by writing a series of control registers. These registers are written through a bidirectional interface which is also used for reading the control registers. The interface consists of an 8-bit data bus, C0-7, a 3 -bit address bus, A0-2, and read/write lines, RD\# and WR\#. The address map for the control registers is shown in Table 1.

Data is written to the control registers on the falling edge of the WR\# input. This requires that the address, $\mathrm{A} 0-2$, and data, $\mathrm{C} 0-7$, be set up to the falling edge of the WR\# as shown in Figure 2. Note: WR\# should not be active low when RD\# is active low.

Data is read from the control registers on the falling edge of the RD\# input. The contents of a particular register are accessed by setting up an address, AO-2, to the falling edge of RD\# as shown in Figure 2. The data is output on C0-7. The data on C0-7 remains valid until RD\# returns HIGH, at which point the $\mathrm{C} 0-7$ bus is Three-Stated and functions as an input. For proper operation, the address on A0-2 must be held until RD\# returns "high" as shown in Figure 2. Note: RD\# should not be active low when WR\# is active low.


FIGURE 2. READ/WRITE TIMING

TABLE 1. CONFIGURATION REGISTERS

| ADDRESS | REGISTER DESCRIPTION | $\begin{gathered} \text { BIT } \\ \text { POSITIONS } \end{gathered}$ | BIT FUNCTION |
| :---: | :---: | :---: | :---: |
| 000 | Filter Configuration | 2-0 | Specifies the number of halfbands to use. Number ranges from 0 to 5 . Other values are invalid. |
|  |  | 3 | FIR filter bypass bit. $0=$ Bypass. |
|  |  | 4 | Coefficient read enable. When set to 1 , enables reading and disables writing of coefficient RAM. Note: this bit must be set to 0 prior to writing the Coefficient RAM. |
|  |  | 7-5 | FIR Decimation Rate. Range is 1-8 $(8=000)$. |
| 001 | Programmable Filter Length | 7-0 | Number of Taps in the Programmable Filter. For even or odd symmetric filters, values range from 4-256, 1 to 3 are invalid, and. $0000000=256$. For asymmetric filters, values range from 2-128. |
| 010 | Coefficient RAM Access | 7-0 | Coefficient RAM is loaded by multiple writes to this address. See Writing Coefficients section for additional details. |
| 011 | Input Format | 4-0 | Number of bits in input data word, from 8 (01000) to 24 (11000). Values outside the range of 8-32 are invalid. |
|  |  | 5 | Number System. $0=$ Two's Complement, $1=$ Offset Binary. |
|  |  | 6 | Serial Format. $1=$ MSB First, $0=$ LSB First. |
|  |  | 7 | Unused |
| 100 | Output Timing | 4-0 | Number of FCLKS per OCLK. Range 1 to 32. (00000=32 FCLKS) |
|  |  | 5 | 1 = MSB First, $0=$ LSB First. |
|  |  | 6-7 | Unused |
| 101 | Output Format | 4-0 | Number of bits in output data word, from 8 to 32. A value of 32 is represented by 00000, and values from 1 to 7 are invalid. |
|  |  | 5 | Round Select. $0=$ Round to Selected Number of Bits, $1=$ Truncate. |
|  |  | 6 | Number System. $0=$ Two's Complement, $1=$ Offset Binary. |
|  |  | 7 | Gain Correction. $1=$ Apply scale factor of 2 to data. $0=$ No Scaling. |
| 110 | Filter Symmetry | 1-0 | $00=$ Symmetric FIR Coefficients $01=$ Non-Symmetric Coefficients $10=$ Odd Symmetric FIR |
|  |  | 7-2 | Unused |
| 111 | Mix Factor Format | 4-0 | Number of bits in mix factor, from 8 (01000) to 24 (11000). Values outside the range of $8-32$ are invalid. |
|  |  | 5 | Serial Format. $1=$ MSB First, $0=$ LSB First. |
|  |  | 6 | Mix Factor Select. $1=$ Serial Input, $0=$ Weaver modulator look-up-table. |
|  |  | 7 | Unused |

## Writing Coefficients

The HSP43124 provides a register bank to store filter coefficients for configurations which use the programmable filter. The register bank consists of 128 thirty-two-bit registers. Each register is loaded by 4 one byte writes to the bidirectional interface used for loading the configuration registers. The coefficients are loaded in order from least significant byte (LSB) to most significant byte (MSB).

The coefficient registers are loaded by first setting the coefficient read enable bit to " 0 " (bit 4 of the Filter Configuration Register). Next, coefficients are loaded by setting the A2-0 address to 010 (binary) and writing one byte at a time as shown in Figure 3. The down loaded bytes are stored in a holding register until the 4th write cycle. On completion of the fourth write cycle, the contents of the holding register are loaded into the Coefficient RAM, and the write pointer is incremented to the next register. If the user attempts to write
more than 128 coefficients, the pointer halts at the 128th register location, and writing is disabled. The coefficient address pointer is reset when any other configuration register is written or read. Note: a new coefficient set may be loaded during a filter calculation at the risk of corrupting output data until the load is complete.


FIGURE 3. COEFFICIENT LOADING
The number of coefficients that must be loaded is dependent on whether the coefficient set exhibits even symmetry, odd symmetry, or asymmetry (see Figure 4).

## EVEN SYMMETRIC



NOTE: Filters with even symmetric coefficients exhibit symmetry about the center of the coefficient set. Most FIR filters have coefficients which are symmetric in nature.

## ODD SYMMETRIC



NOTE: Odd symmetric coefficients have a coefficient envelope which has the characteristics of an odd function (i.e. coefficients which are equidistant from the center of the coefficient set are equal in magnitude but opposite in sign). Coefficients designed to function as a differentiator or Hilbert Transform exhibit these characteristics.

## ASYMMETRIC



NOTE: Asymmetric Coefficient sets exhibit no symmetry.
FIGURE 4. COEFFICIENT CHARACTERISTICS
For filters that exhibit either even or odd symmetry, only the unique half of the coefficient set must be loaded. The coefficients are loaded in order starting with the first filter tap and ending with the center tap. The coefficient associated with the first tap is the first to be multiplied by an incoming data sample as shown in Figure 5. For even/odd symmetric filters
of length $N, N / 2$ coefficients must be loaded if the filter length is even, and $(\mathrm{N}+1) / 2$ coefficients must be loaded if the filter length is odd. For example, a 17 tap symmetric filter would require the loading of 9 coefficients. Enough storage is provided for a 256 tap symmetric filter.


FIGURE 5. THREE TAP TRANSVERSAL FILTER ARCHITECTURE
For asymmetric filters the entire coefficient set must be loaded. The coefficients are loaded in order starting with the first tap and ending with the final filter tap (see Figure 5 for tap/coefficient association). Enough storage is provided for a 128 tap asymmetric filter.

## Reading Coefficients

The coefficients are read from the storage registers one byte at a time via $\mathrm{C} 0-7$ as shown in Figure 6. To read the coefficients, the user first sets the Coefficient Read Enable bit to 1 (bit 4 of Filter Configuration Register). Setting this bit resets the RAM read pointer and disables the RAM from being written. Next, with A2-0 $=010$, multiple "high" to "low" transitions of RD\#, output the coefficients on C0-7, one byte at a time, in the order they were written. Note: RD\# should not be "low" when WR\# is "low".


FIGURE 6. COEFFICIENT READING

## Data Input

Data is serially input to the HSP43124 through the DIN input. On the rising edge of SCLK, the bit value present at DIN is clocked into the Variable Length Shift Register. The beginning of a serial data word is designated by asserting SYNCIN "high" one SCLK prior to the first data bit as shown in Figure 7. On the following SCLK, the first data bit is clocked into the Variable Length Shift Register. Data bits are clocked into the shift register until the data word, of user programmable length ( 8 to 24 -bits), is complete. At this point, the shifting of data into the register is disabled and its contents are held until SYNCIN is asserted on the rising
edge of SCLK. When this occurs, the contents of the Variable Length Shift Register are transferred to the Input Holding Register, and the shift register is enabled to accept serial data on the following SCLK. The serial data word may be two's complement or offset binary and may be input most significant bit (MSB) first or least significant bit (LSB) first as defined in the Input Format Register (see Table 1). If a data word is specified to be less than 24-bits, the least significant bits of the Input Holding Register are zeroed. Note: SYNCIN should not be "high" for longer than one SCLK cycle.


NOTE: Assumes data is being loaded LSB first.

## FIGURE 7. SERIAL INPUT TIMING FOR EITHER DIN OR MXIN

 INPUTS
## Mix Factor

The HSP43124 provides a second serial interface for loading values which are multiplied by the input samples in the serial multiplier. These values, or mix factors, are input using the MXIN and SYNCMX pins. Aside from being used as a serial input, this interface can also be used to select mix factors from the Weaver Modulator ROM. The mix factor source is specified in the Mix Factor Format Register (see Table 1). Note: data is passed unmodified through the serial multiplier by selecting the Weaver Modulation ROM as the mix factor source and tieing both SYNCMX and MXIN "high".

The procedure for loading mix factors serially is similar to that for the loading of data via the DIN input. The bit value present on MXIN is clocked into the Variable Length Shift register by the rising edge of SCLK. The beginning of the serial word is designated by the assertion of SYNCMX one SCLK prior to the first bit of the serial word as shown in Figure 7. After the serial word has been clocked into the shift register, the shifting of bits into the register is disabled and its contents are held until the next assertion of SYNCMX. When SYNCMX is asserted on the rising edge of SCLK, the contents of the Variable Length Shift register are transferred into the Mix Factor Holding Register. The parallel output of the Mix Factor Holding Register feeds directly into the serial multiplier. The mix factor data word is programmable in length from 8 to 24-bits and may be input MSB or LSB first as specified in the Mix Factor Format Register. If a data word is specified to be less than 24-bits, the least significant bits of the Mix Factor Holding Register are zeroed.

In configurations which use the Weaver Modulator ROM to generate the mix factors, the MXIN and SYNCMX inputs function as ROM addresses. These inputs are latched on the rising edge of SCLK when SYNCIN is high as shown in Figure 9. The mapping of SYNCIN and MXIN to ROM outputs is
given in Table 2. When SYNCIN is high on the rising edge of SCLK, the output of the ROM is transferred to the Mix Factor holding register, and the SYNCMX and MXIN inputs are decoded to produce a new ROM output. As a result, there is a latency of one SYNCIN cycle between when the SYNCMX and MXIN inputs are decoded and when the ROM output is loaded into the Mix Factor Holding register.

TABLE 2. WEAVER MODULATOR ROM DECODING

| SYNCMX | MXIN | MIX FACTOR |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | -1 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

## Serial Multiplier

The Serial Multiplier multiplies the Mix Factor Holding register by the contents of the Input Holding register. The multiplication cycle is initiated when SYNCIN is sampled high by the rising edge of SCLK. This transfers the contents of the Variable Length Shift register to the Input Holding Register, and loads the output of the Mix Factor Holding Register into the Serial Multipler. On subsequent SCLK's, the contents of the Input Holding Register are shifted into the Serial Multiplier for processing. When the last data bit is shifted into the multiplier, the multiplication cycle is complete and the result is written to the Register File on the next rising edge of FCLK.

The synchronization between a data sample and the mix factor it is to be multiplied by is dependent on which mix factor source is specified. For mix factors which are input serially, the mix factor is loaded concurrently with the data sample is to be multiplied by (see Figure 8).


FIGURE 8. DATAMMIX FACTOR SYNCHRONIZATION FOR SE-
RIALLY INPUT MIX FACTORS
NOTE: Figure 8 shows the loading of a data sample, X 0 , such that it will be multiplied by a mix factor designated by MO. For mix factor bit widths which are less than the input bit width, SYNCMX may be asserted before SYNCIN if desired.

If the mix factor is generated by the Weaver Modulator ROM, the mix factor must be specified on MXIN and SYNCMX one SYNCIN before that which precedes the target data word (see Figure 9).


## FIGURE 9. DATAMIX FACTOR SYNCHRONIZATION WEAVER MODULATOR MIX FACTORS

NOTE: Figure 9 shows the specification of a ROM based mix factor, M0, so that it will be multiplied with the target data sample designated by X .

## Filter Compute Engine

The Filter Compute Engine centers around a multiply accumulator which is used to perform the sum-of-products required for a variety of filtering configurations. These configurations include a cascade of up to 5 halfband filters, a single symmetric filter of up to 256 taps, a single asymmetric filter of up to 128 taps, or a cascade of halfband filters followed by a programmable filter. The filter configuration is specified by programming the Filter Configuration Register (see Table 1).

The cascade of up to five halfband filters is an efficient decimating filter structure. Each fixed coefficient filter in the chain introduces a decimation of two, and the aggregate decimation rate of the entire halfband filtering stage is given by

$$
D E C_{H B}=2^{(\text {NUMBER OF HALFBAND FILTERS SELECTED })}
$$

Thus, a cascade of 3 halfband filters would decimate the input sample stream by a factor of 8 .

The frequency responses of the five filters is presented graphically in Figure 10 and in tabular form in Table 3. The transition band for the fifth halfband filter, HB5, is the narrowest while that for the first halfband filter, HB1, is the widest. The cascade of the halfband filters always terminates with HB5 and is preceded by filters in order of increasing transition bandwidth. For example, if the HSP43124 is configured to operate with three halfbands, the chain of filters would consist of HB3 followed by HB4 and terminated with HB5. If only one halfband is selected, HB5 is used.


FIGURE 10. COMPOSITE RESPONSE OF FIXED COEFFICIENT HALFBAND FILTERS

The coefficients for each of the halfband filters is given in Table 4. These values are the 32-bit, two's complement, integer representation of the filter coefficients. Scaling these values by $2^{-34}$ yields the fractional two's complement coefficients used to achieve unity gain in the Filter Processor.

If a specific frequency response is desired, a programmable filter may be activated. The filter compute engine takes advantage of symmetry in FIR coefficients is by summing data samples sharing a common coefficient prior to multiplication. In this manner, two filter taps are calculated per multiply accumulate cycle. If an asymmetric filter is specified, only one tap per multiply accumulate cycle is calculated.

The processing rate of the Filter Compute Engine is proportional to FCLK. As a result, the frequency of FCLK must exceed a minimum value to insure that a filter calculation is complete before the result is required for output. In configurations which do not use decimation, one input sample period is available for filter calculation before an output is required. For configurations which employ decimation, up to 256 input sample periods may be available for filter calculation. The following equation specifies the minimum FCLK rate required for configurations which use the programmable filter as an FIR filter.

Min FCLK $=\left(F_{S} / D E C_{H B}\right)\left(T A P S /\left(2 * D E C_{F I R}\right)+H_{C L K S}+1\right)$
In this equation $\mathrm{F}_{\mathrm{S}}$ is the sample rate, TAPS is the number of taps in the FIR filter ( 0 to 256), DEC FIR is the decimation rate of the programmable FIR ( 1 to 8 ), and $\mathrm{HB}_{\text {CLKs }}$ is a compute clock factor based on the number of halfband filters in the configuration (see Table 5). The term DEC $\mathrm{HB}_{\mathrm{HB}}$ is the aggregate decimation rate for the cascade of halfband filters (see Table 5). For example, if the input sample rate is 800 kHz , a 128 tap FIR filter with no decimation is selected, and a cascade of 2 halfband filters is used, a minimum FCLK rate of 19.6 MHz would be required. Note: for configurations in which the halfband filters are used, the FCLK rate must exceed $14 \mathrm{~F}_{\mathrm{S}}$.

HSP43124

TABLE 3. FREQUENCY RESPONSE OF HALFBAND FILTERS

| NORMALIZED FREQUENCY | HALFBAND \#1 | HALFBAND \#2 | HALFBAND \#3 | HALFBAND \#4 | HALFBAND \#5 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0.000000 | -0.000000 | 0.000000 | 0.000000 | -0.000000 | -0.000000 |
| 0.007812 | 0.000000 | -0.000000 | -0.000000 | -0.000000 | -0.000000 |
| 0.015625 | -0.000113 | -0.000000 | -0.000000 | -0.000000 | -0.000000 |
| 0.023438 | -0.000677 | -0.000006 | -0.000000 | -0.000000 | -0.000000 |
| 0.031250 | -0.002243 | -0.000052 | -0.000000 | -0.000000 | -0.000000 |
| 0.039062 | -0.005569 | -0.000227 | -0.000000 | -0.000000 | 0.000000 |
| 0.046875 | -0.011596 | -0.000719 | -0.000001 | 0.000000 | -0.000000 |
| 0.054688 | -0.021433 | -0.001859 | -0.000009 | -0.000000 | -0.000000 |
| 0.062500 | -0.036333 | -0.004165 | -0.000041 | -0.000000 | -0.000000 |
| 0.070312 | -0.057670 | -0.008391 | -0.000149 | -0.000001 | -0.000000 |
| 0.078125 | -0.086916 | -0.015557 | -0.000448 | -0.000012 | -0.000000 |
| 0.085938 | -0.125619 | -0.026983 | -0.001175 | -0.000066 | -0.000000 |
| 0.093750 | -0.175382 | -0.044301 | -0.002767 | -0.000258 | -0.000000 |
| 0.101562 | -0.237843 | -0.069457 | -0.005963 | -0.000815 | -0.000000 |
| 0.109375 | -0.3¢4663 | -0.104701 | -0.011924 | -0.002208 | -0.000000 |
| 0.117188 | -0.407509 | -0.152566 | -0.022368 | -0.005313 | -0.000000 |
| 0.125000 | -0.518045 | -0.215834 | -0.039695 | -0.011613 | -0.000000 |
| 0.132812 | -0.647925 | -0.297499 | -0.067100 | -0.023435 | -0.000031 |
| 0.140625 | -0.798791 | -0.400727 | -0.108640 | -0.044186 | -0.000287 |
| 0.148438 | -0.972266 | -0.528809 | -0.169262 | -0.078552 | -0.001468 |
| 0.156250 | -1.169959 | -0.685131 | -0.254777 | -0.132639 | -0.005427 |
| 0.164062 | -1.393465 | -0.873129 | -0.371785 | -0.214009 | -0.016180 |
| 0.171875 | -1.644372 | -1.096269 | -0.527552 | -0.331613 | -0.041152 |
| 0.179688 | -1.924262 | -1.358019 | -0.729872 | -0.495620 | -0.092409 |
| 0.187500 | -2.234728 | -1.661842 | -0.986908 | -0.717181 | -0.187497 |
| 0.195312 | -2.577375 | -2.011181 | -1.307047 | -1.008144 | -0.349593 |
| 0.203125 | -2.953834 | -2.409468 | -1.698769 | -1.380771 | -0.606862 |
| 0.210938 | -3.365774 | -2.860128 | -2.170548 | -1.847495 | -0.991193 |
| 0.218750 | -3.814917 | -3.366593 | -2.730783 | -2.420719 | -1.536664 |
| 0.226562 | -4.303048 | -3.932319 | -3.387764 | -3.112694 | -2.278126 |
| 0.234375 | -4.832037 | -4.560817 | -4.149669 | -3.935463 | -3.250174 |
| 0.242188 | -5.403856 | -5.255675 | -5.024594 | -4.900864 | -4.486639 |
| 0.250000 | -6.020599 | -6.020600 | -6.020600 | -6.020600 | -6.020600 |
| 0.257812 | -6.684504 | -6.859450 | -7.145791 | -7.306352 | -7.884833 |
| 0.265625 | -7.397981 | -7.776287 | -8.408404 | -8.769932 | -10.112627 |
| 0.273438 | -8.163642 | -8.775419 | -9.816921 | -10.423476 | -12.738912 |
| 0.281250 | -8.984339 | -9.861469 | -11.380193 | -12.279667 | -15.801714 |
| 0.289062 | -9.863195 | -11.039433 | -13.107586 | -14.352002 | -19.344007 |

HSP43124
table 3. frequency response of halfband filters (Continued)

| NORMALIZED FREQUENCY | HALFBAND * 1 | HALFBAND \#2 | $\begin{gathered} \text { HALFBAND } \\ \# 3 \end{gathered}$ | HALFBAND *4 | HALFBAND \#5 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0.296875 | -10.803663 | -12.314765 | -15.009147 | -16.655094 | -23.416153 |
| 0.304688 | -11.809574 | -13.693460 | -17.095793 | -19.205034 | -28.079247 |
| 0.312500 | -12.885208 | -15.182171 | -19.379534 | -22.019831 | -33.409992 |
| 0.320312 | -14.035372 | -16.788332 | -21.873730 | -25.119940 | -39.508194 |
| 0.328125 | -15.265501 | -18.520315 | -24.593418 | -28.528942 | -46.509052 |
| 0.335938 | -16.581776 | -20.387625 | -27.555685 | -32.274414 | -54.604954 |
| 0.343750 | -17.991278 | -22.401131 | -30.780161 | -36.389088 | -64.087959 |
| 0.351562 | -19.502172 | -24.573368 | -34.289623 | -40.912403 | -75.444221 |
| 0.359375 | -21.123947 | -26.918915 | -38.110786 | -45.892738 | -89.610390 |
| 0.367188 | -22.867725 | -29.454887 | -42.275345 | -51.390583 | -108.973686 |
| 0.375000 | -24.746664 | -32.201569 | -46.821358 | -57.483341 | -152.503693 |
| 0.382812 | -26.776485 | -35.183285 | -51.795181 | -64.272881 | -153.443375 |
| 0.390625 | -28.976198 | -38.429543 | -57.254162 | -71.898048 | -158.914017 |
| 0.398438 | -31.369083 | -41.976673 | -63.270584 | -80.556969 | -156.960175 |
| 0.406250 | -33.984089 | -45.870125 | -69.937607 | -90.550629 | -153.317627 |
| 0.414062 | -36.857830 | -50.167850 | -77.378593 | -102.379677 | -161.115540 |
| 0.421875 | -40.037594 | -54.945438 | -85.762718 | -117.007339 | -153.504684 |
| 0.429688 | -43.585945 | -60.304272 | -95.332924 | -136.890198 | -158.650345 |
| 0.437500 | -47.588165 | -66.385063 | -106.462181 | -185.130432 | -154.637756 |
| 0.445312 | -52.164894 | -73.392075 | -119.793030 | -187.297241 | -153.870453 |
| 0.453125 | -57.495132 | -81.640152 | -136.802948 | -182.300125 | -161.882385 |
| 0.460938 | -63.861992 | -91.658478 | -175.030167 | -203.460876 | -152.278915 |
| 0.468750 | -71.755898 | -104.468010 | -158.939362 | -174.691895 | -164.329758 |
| 0.476562 | -82.156616 | -122.641861 | -157.095886 | -174.737076 | -153.535690 |
| 0.484375 | -97.627930 | -166.537369 | -155.613434 | -175.108841 | -153.507477 |
| 0.492188 | -139.751450 | -165.699081 | -154.708450 | -169.966568 | -167.665482 |

TABLE 4. HALFBAND FILTER COEFFICIENTS (32-BITS, UN-NORMALIZED)

| COEFFICIENT | HALFBAND \#1 | HALFBAND \#2 | HALFBAND \#3 | HALFBAND \#4 | HALFBAND \#5 |
| :---: | ---: | ---: | ---: | ---: | ---: |
| C0 | -67230275 | 12724188 | 624169 | -197705 | 23964 |
| C1 | 0 | 0 | 0 | 0 | 0 |
| C2 | 604101076 | -105279784 | -6983862 | 2303514 | -242570 |
| C3 | 1073741823 | 0 | 0 | 0 | 0 |
| C4 | 604101076 | 629426509 | 38140187 | -13225905 | 1306852 |
| C5 | 0 | 1073741827 | 0 | 0 | 0 |
| C6 | -67230275 | 629426509 | -145867861 | 51077176 | -4942818 |
| C7 |  | 0 | 0 | 0 | 0 |
| C8 |  | -105279784 | 650958284 | -161054660 | 14717750 |

TABLE 4. HALFBAND FILTER COEFFICIENTS (32-BITS, UN-NORMALIZED) (Continued)

| COEFFICIENT | HALFBAND \#1 | HALFBAND \#2 | HALFBAND \#3 | HALFBAND \#4 | HALFBAND ${ }^{\text {\% }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| C9 |  | 0 | 1073741793 | 0 | 0 |
| C10 |  | 12724188 | 650958284 | 657968488 | -37027884 |
| C11 |  |  | 0 | 1073741825 | 0 |
| C12 |  |  | -145867861 | 657968488 | 84032070 |
| C13 |  |  | 0 | 0 | 0 |
| C14 |  |  | 38140187 | -161054660 | -191585682 |
| C15 |  |  | 0 | 0 | 0 |
| C16 |  |  | -6983862 | 51077176 | 670589251 |
| C17 |  |  | 0 | 0 | 1073741824 |
| C18 |  |  | 624169 | -13225905 | 670589251 |
| C19 |  |  |  | 0 | 0 |
| C20 |  |  |  | 2303514 | -191585682 |
| C21 |  |  |  | 0 | 0 |
| C22 |  |  |  | -197705 | 84032070 |
| C 23 |  |  |  |  | 0 |
| C24 |  |  |  |  | -37027884 |
| C25 |  |  |  |  | 0 |
| C26 |  |  |  |  | 14717750 |
| C 27 |  |  |  |  | 0 |
| C28 |  |  |  |  | -4942818 |
| C29 |  |  |  |  | 0 |
| C30 |  |  |  |  | 1306852 |
| C31 |  |  |  |  | 0 |
| C32 |  |  |  |  | -242570 |
| C33 |  |  |  |  | 0 |
| C34 |  |  |  |  | 23964 |

TABLE 5. PERFORMANCE ENVELOPE PARAMETERS

| NUMBER OF <br> HALFBANDS | HB $_{\text {CLKS }}$ | DEC $_{\text {HB }}$ |
| :---: | :---: | :---: |
| 0 | 0 | 1 |
| 1 | 13 | 2 |
| 2 | 33 | 4 |
| 3 | 69 | 8 |
| 4 | 125 | 16 |
| 5 | 221 | 32 |

The longest length FIR filter realizable for a particular configuration is determined by solving the above equation for TAPS. The resulting expression is given below.

Max TAPS $=$ 2DEC $_{\text {FIR }}\left(\right.$ (FCLK/F $\left._{S}\right)$ DEC HB - HB $\left._{\text {CLKS }}-1\right)$
The maximum throughput sample rate may be specified by solving the above equation for $F_{S}$. The resulting equation is

NOTE: for configurations using filters with asymmetric coefficients, the term TAPS in the above equations should be multiplied by two in order to determine the correct FCLK.

The Filter Compute Engine is synchronized with an incoming data stream by asserting the FYSNC\# input. When this input is sample low by the rising edge of FCLK, the Compute Engine is reset, and the data word following the next assertion of SYNCIN is recognized as the first data sample input to the filter structure.

## Serial Output Formatter

The Output Formatter serializes the parallel output of the filter compute engine while generating the timing and synchronization signals required to support a serial interface. The Formatter produces serial data words with programmable lengths from 8 to 32 -bits. The data words may be organized with either most or least significant bit first. Also, the data word may be rounded or truncated to the desired length and the format of the output data may be specified as either two's complement or offset binary. To simplify applications where the Serial I/O Filter is used as a down converter, the output formatter can be configured to scale the output by a factor of 2 . The above options are programmed via the Output Format and Output Timing Registers given in Table 1.
The HSP43124 outputs a bit stream through DOUT which is synchronous to a programmiable clock signal output on CLKOUT. The output clock, CLKOUT, is derived from FCLK and has a programmable rate from 1 to $\frac{1 / 32}{}$ times FCLK. The duty cycle of CLKOUT is $50 \%$ for rates that have an even number of FCLK's per CLKOUT. For rates that have and odd number of FCLK's per OCLK the high portion of the CLKOUT waveform spans $(n+1) / 2$ FCLK's and the low portion spans ( $n-1$ )/2 FCLK's where $n$ is the number of FCLK's.

External devices synchronize to the beginning of an output data word by monitoring SYNCOUT. This output is asserted "high" one CLKOUT prior to the first bit of the next data word as shown in Figure 11.


NOTE: Assumes data is being output LSB first.
FIGURE 11. SERIAL OUTPUT TIMING

## Input and Output Data Formats

The data formats for the input, output and coefficients are fractional two's complement. The bit weighting's in the data words are given in Figure 12. Input or output data words programmed to have less than 24-bits, map to the most significant bit positions of the 24 -bit word. For example, an input word defined to be 8-bits wide would map to the bit positions with weightings from $-2^{0}$ to $2^{-7}$.

FRACTIONAL TWO'S COMPLEMENT FORMAT FOR 24-BIT INPUT AND OUTPUT

$-2^{0} .2^{-1} 2^{-2} 2^{-3} 2^{-4} 2^{-5} 2^{-6} 2^{-7} 2^{-8} 2^{-9} 2^{-10} 2^{-11} 2^{-12} 2^{-13} 2^{-14} 2^{-15} 2^{-16} 2^{-17} 2^{-18} 2^{-19} 2^{-20} 2^{-21} 2^{-22} 2^{-23}$

FRACTIONAL TWO'S COMPLEMENT FORMAT FOR 32-BIT COEFFICIENTS

$-2^{0} 2^{-1} 2^{-2} 2^{-3} 2^{-4} 2^{-5} 2^{-6} 2^{-7} 2^{-8} 2^{-9} 2^{-10} 2^{-11} 2^{-12} 2^{-13} 2^{-14} 2^{-15} 2^{-16} 2^{-17} 2^{-18} 2^{-19} 2^{-20} 2^{-21} 2^{-22} 2^{2-23} 2^{244} 2^{-25} 2^{-26} 2^{-22} 2^{-28} 2^{-28} 2^{-30} 2^{-31}$

FIGURE 12. DATA FORMATS

## Absolute Maximum Ratings



CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range (Commercial). . . . . . . . . . 4.75 V to 5.25 V Operating Temperature Range (Commercial) . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
DC Electrical Specifications $\quad\left(V_{C C}=5.0 V_{ \pm} 5 \%, T_{A}=0^{\circ}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Current | ICCOP | $\bullet$ | 203 | mA | $\begin{aligned} & V_{C C}=\text { Max, FCLK }=S C L K=45 \mathrm{Mhz} \\ & \text { Notes } 1,2 \end{aligned}$ |
| Standby Power Supply Current | Iccss | $\bullet$ | 500 | UA | $\mathrm{V}_{C C}=$ Max, Outputs Not Loaded |
| Input Leakage Current | 1 | -10 | 10 | UA | $V_{C C}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{C C}$ |
| Output Leakage Current | 10 | -10 | 10 | V | $\mathrm{V}_{C C}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{C C}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $V_{C C}=$ Max, FCLK and SCLK |
| Clock Input Low | $V_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=$ Min, FCLK and SCLK |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{iH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical One Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{IOH}=-5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical Zero Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 10 | pF | $\text { FCLK }=\text { SCLK }=1 \mathrm{MHz}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | $\bullet$ | 10 | pF | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \text {, Note } 3$ |

NOTES:

1. Power supply current is proportional to frequency. Typical rating is $4.5 \mathrm{~mA} / \mathrm{MHz}$.
2. Output load per test circuit and $C_{L}=40 \mathrm{pF}$.
3. Not tested, but characterized at initial design and at major process/design changes.

AC Electrical Specifications (Note 1) $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}_{ \pm} 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | 45MHz |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| FCLK, SCLK Period | $T_{C P}$ | 22 | - | ns |
| FCLK, SCLK High | $\mathrm{T}_{\mathrm{CH}}$ | 8 | - | ns |
| FCLK, SCLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 8 | - | ns |
| Setup Time DIN, MXIN, SYNCIN, SYNCMX to SCLK | $\mathrm{T}_{\mathrm{DS}}$ | 8 | - | ns |
| Hold Time DIN, MXIN, SYNCIN, SYNCMX from SCLK | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | ns |
| Setup Time FSYNC to FCLK | TSS | 8 | - | ns |
| Hold Time FSYNC from FCLK | TSH | 0 | - | ns |
| Setup Time C0-7, A0-2 to Falling Edge of WR\# | Tws | 10 | - | ns |
| Hold Time C0-7, A0-2 from Falling Edge of WR\# | $\mathrm{T}_{\text {WH }}$ | 3 | - | ns |
| Setup Time A0-2 to Falling Edge of RD\# | $\mathrm{T}_{\text {RS }}$ | 10 | - | ns |
| Hoid Time A0-2 from Rising Edge of RD\# | $\mathrm{T}_{\text {RH }}$ | 0 | - | ns |
| WR\# High | $\mathrm{T}_{\text {WRH }}$ | 10 | - | ns |
| WR\# Low | $T_{\text {WRL }}$ | 10 | - | ns |
| RD\# High | $\mathrm{T}_{\text {RDH }}$ | 10 | - | ns |
| RD\# Low to Data Valid | $\mathrm{T}_{\text {ROO }}$ | - | 25 | ns |
| RD\# High to Output Disable | TOD | $\bullet$ | 6 | ns |
| FCLK to CLKOUT | $\mathrm{T}_{\text {FOC }}$ | - | 12 | ns |
| CLKOUT to SYNCOUT, DOUT | $\mathrm{T}_{\mathrm{DO}}$ | - | 8 | ns |
| Output Rise, Fall Time | $\mathrm{T}_{\text {RF }}$ | - | 3 | ns, Note 2 |

## NOTES:

1. AC tests performed with $C_{L}=40 \mathrm{pF}, \mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$, and $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$. Input reference level for FCLK and SCLK is 2.0 V , all other inputs 1.5 V . Test $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{LL}}=0 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.

## AC Test Load Circuit



## Waveforms

TIMING RELATIVE TO WR\#


OUTPUT RISE AND FALL TIMES


## INPUT DATA TIMING



TIMING RELATIVE TO READ

timing relative to flck and clkout


## Features

- Two Independent 8-Tap FIR Filters Configurable as a Single 16-Tap FIR
- 10-Bit Data \& Coefficients
- On-Board Storage for 32 Programmable Coefficient Sets
- Up To: 256 FIR Taps, $16 \times 16$ 2-D Kernels, or $10 \times 19$-Bit Data and Coefficients
- Programmable Decimation to 16
- Programmable Rounding on Output
- Standard Microprocessor Interface


## Applications

- Quadrature, Complex Filtering
- Image Processing
- PolyPhase Filtering
- Adaptive Filtering


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :--- | :--- |
| HSP43168VC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43168VC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43168JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43168JC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43168GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP43168GC-45 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The HSP43168 Dual FIR Filter consists of two independent 8 -tap FIR filters. Each filter supports decimation from 1 to 16 and provides on-board storage for 32 sets of coefficients. The Block Diagram shows two FIR cells each fed by a separate coefficient bank and one of two separate inputs. The outputs of the FIR cells are either summed or multiplexed by the MUX/Adder. The compute power in the FIR Cells can be configured to provide quadrature filtering, complex filtering, 2-D convolution, 1-D/2-D correlations, and interpolating/decimating filters.

The FIR cells take advantage of symmetry in FIR coefficients by pre-adding data samples prior to multiplication. This allows an 8 -tap FIR to be implemented using only 4 multipliers per filter cell. These cells can be configured as either a single 16 -tap FIR filter or dual 8 -tap FIR filters. Asymmetric filtering is also supported.

Decimation of up to 16 is provided to boost the effective number of filter taps from 2 to 16 times. Further, the decimation registers provide the delay necessary for fractional data conversion and 2-D filtering with kernels to $16 \times 16$.

The flexibility of the Dual is further enhanced by 32 sets of user programmable coefficients. Coefficient selection may be changed asynchronously from clock to clock. The ability to toggle between coefficient sets further simplifies applications such as polyphase or adaptive filtering.

The HSP43168 is a low power fully static design implemented in an advanced CMOS process. The configuration of the device is controlled through a standard microprocessor interface.

## Block Diagram




84 PIN PLCC
TOP VIEW


## Pinouts (Continued)

100 LEAD MQFP
TOP VIEW


## Pin Description

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | $\begin{gathered} \text { B5, D11, K10 } \\ \text { K7, F1 } \end{gathered}$ |  | VCC: +5 V power supply pin. |
| GND | $\begin{gathered} \text { A9, E10, L11 } \\ \text { K4, D2 } \end{gathered}$ |  | Ground. |
| CINO-9 | $\begin{gathered} \text { E1-3, D1, } \\ \text { C1-2, B1-3, } \\ \text { A1 } \end{gathered}$ | 1 | Control/Coefficient Data Bus. Processor interface for loading control data and coefficients. CINO is the LSB. |
| AO-8 | $\begin{gathered} \mathrm{A} 5-8, \mathrm{~B} 6-8 \\ \mathrm{C} 6-7 \end{gathered}$ | 1 | Control/Coefficient Address Bus. Processor interface for addressing control and coefficient registers. AO is the LSB. |
| WR\# | A10 | 1 | Control/Coefficient Write Clock. Data is latched into the control and coefficient registers on the rising edge of WR\#. |
| CSELO-4 | A2-4, B4, C5 | I | Coefficient Select. This input determines which of the 32 coefficient sets are to be used by FIR A and B. This input is registered and CSELO is the LSB. |
| INAO-9 | $\begin{gathered} \mathrm{K} 1, \mathrm{~J} 1-2, \\ \mathrm{H} 1-2, \mathrm{G} 1-3, \\ \text { F2-3 } \end{gathered}$ | 1 | Input to FIR A. INAO is the LSB |
| INBO-9 | $\begin{gathered} \mathrm{L} 1-5, \mathrm{~K} 2-3 \\ \mathrm{~K} 5-6, \mathrm{~J} 5 \end{gathered}$ | 1/O | Bidirectional Input for FIR B. INBO is the LSB and is input only. When used as output, INB1-9 are the LSB's of the output bus, and INB9 is the MSB of these bits. |
| OUT9-27 | $\begin{gathered} \text { F9-11, G9-11, } \\ \text { H10-11, J10-11 } \\ \text { J7, K11, } \\ \text { K8-9, L6-10 } \end{gathered}$ | 0 | 19 MSB's of Output Bus. Data format is either unsigned or two's complement depending on configuration. OUT27 is the MSB. |
| SHFTEN\# | B11 | 1 | Shift Enable. This active low input enables clocking of data into the part and shifting of data through the decimation registers. |
| FWRD\# | C10 | 1 | Forward ALU Input Enable. When active low, data from the forward decimation path is input to the ALU's through the " $a$ " input. When high, the " $a$ " inputs to the ALUs are zeroed. |
| RVRS\# | A11 | I | Reverse ALU Input Enable. When active low, data from the reverse decimation path is input to the ALU's through the " $b$ " input. When high, the " $b$ " inputs to the ALUs are zeroed. |
| TXFR\# | C11 | 1 | Data Transfer Control. This active low input switches the LIFO being read into the reverse decimation path with the LIFO being written from the forward decimation path (see Figure 1). |
| MUXO-1 | B9-10 | 1 | Adder/Mux Control. This input controls data flow through the output Adder/Mux. Table 3.0 lists the various configurations. |
| CLK | E9 | 1 | Clock. All inputs except those associated with the processor interface (CINO-9, AO-8, WR\#) and the output enables (OEL\#, OEH\#) are registered by the rising edge of CLK. |
| OEL\# | $J 6$ | 1 | Output Enable Low. This tristate control enables the LSB's of the output bus to INB1-9 when OEL\# is low. |
| OEH\# | E11 | 1 | Output Enable High. This tristate control enables OUT9-27 when OEH\# is low. |
| ACCEN | D10 | 1 | Accumulate Enable. This active high input allows accumulation in the FIR Cell Accumulator. A low on this input latches the FIR Accumulator contents into the Output Holding Registers while zeroing the feedback path in the Accumulator. |



## Functional Description

As shown in Figure 1.0, the HSP43168 consists of two 4multiplier FIR filter cells which process 10 bit data and coefficients. The FIR cells can operate as two independent 8-tap FIR filters or two 4-tap asymmetric filters at maximum I/O rates. A single filter mode is provided which allows the FIR cells to operate as one 16 -tap FIR filter or one 8-tap asymmetric filter. On board coefficient storage for up to 32 sets of 8 coefficients is provided. The coefficient sets are user selectable and are programmed through a microprocessor interface. Programmable decimation to 16 is also provided. By utilizing decimation registers together with the coefficient sets, polyphase filters are realizable which allow the user to trade data rate for filter taps. The MUX/ Adder can be configured to either add or multiplex the outputs of the filter cells depending upon whether the cells are operating in single or dual filter mode. In addition, a shifter in the MUX/Adder is provided for implementation of filters with 10 bit data and 20 bit coefficients or vice versa.

## Microprocessor Interface

The Dual has a 20 pin write only microprocessor interface for loading data into the Control Block and Coefficient Bank. The interface consists of a 10-bit data bus (CINO-9), a 9 bit address bus (AO-8), and a write input (WR\#) to latch the data into the on-board registers. The control and coefficient data can be loaded asynchronously to CLK.

## Control Block

The Dual FIR is configured by writing to the registers within the Control Block. These registers are memory mapped to address 000 H ( $\mathrm{H}=$ Hexadecimal) and 001 H on $\mathrm{AO}-8$. The format of these registers is shown in Table 1 and Table 2. Writing the Control/Configuration registers causes a reset which lasts for 6 CLK cycles following the assertion of WR\#. The reset caused by writing registers in the Control Block will not clear the contents of the Coefficient Bank.

TABLE 1

| CONTROL ADDRESS OOOH |  |  |
| :---: | :--- | :--- |
| BITS | FUNCTION | DESCRIPTION |
| $3-0$ | Decimation Factor | $0000=$ No Decimation <br> $1111=$ Decimation by 16 |
| 4 | Mode Select | $0=$ Single Fllter Mode <br> $1=$ Dual FIlter Mode |
| 5 | Odd/Even Symmetry | $0=$ Even symmetric coefficients <br> $1=$ Odd symmetric coefficients |
| 6 | FIRA odd/even taps | $0=$ Odd number of taps in filter <br> $1=$ Even number of taps in filter |
| 7 | FIR B odd/even taps | (Defined same as FIR A above) |
| 8 | FIR B Input Source | $0=$ Input from INAO-9 <br> $1=$ Input from INBO-9 |
| 9 | Not Used | Set to 0 for proper operation |

The 4 LSBs of the control word loaded at address 000 H are used to select the decimation factor. For example, if the 4

LSBs are programmed with a value of 0010, the forward and reverse shifting decimation registers are each configured with a delay of 3 . Bit 4 is used to select whether the FIR cells operate as two independent filters or one extended length filter. Coefficient symmetry is selected by bit 5. Bits 6 and 7 are programmed to configure the FIR cells for odd or even filter lengths. Bit 8 selects the FIR B input source when the FIR cells are configured for independent operation. Bit 9 must be programmed to 0 .

The 4 LSB's of the control word loaded at address 001 H are used to configure the format of the FIR cell's data and coefficients. Bit 4 is programmed to enable or disable the reversal of data sample order prior to entering the backward shifting decimation registers. Bits 5-9 are used to support programmable rounding on the output.

TABLE 2

| CONTROL ADDRESS 001H |  |  |
| :---: | :--- | :--- |
| BITS | FUNCTION | DESCRIPTION |
| 0 | FIR A Input Format | $0=$ Unsigned <br> $1=$ Two's Complement |
| 1 | FIR A Coefficient <br> Format | (Defined same as FIR A input) |
| 2 | FIR B Input Format | (Defined same as FIR A input) |
| 3 | FIR B Coefficient | (Defined same as FIR A input) |
| 4 | Data Reversal <br> Enable | $0=$ Enabled <br> $1=$ Disabled |
| $8-5$ | Round Position | $0000=2^{-10}$ <br> $1011=2^{1}$ |
| 9 | Round Enable | $0=$ Enabled <br> $1=$ Disabled |

NOTE: Address locations 002 H to OffH are reserved, and writing to these locations will have unpredictable effects on part configuration.

## FIR Filter Cells

Each FIR filter cell is based on an array of four $11 \times 10$ bit two's complement multipliers. The multipliers get one input from the ALUs which combine data shifting through the forward and backward decimation registers. The second input comes from the user programmable coefficient bank. The multiplier outputs feed an accumulator whose result is passed to the output section where it is multiplexed or added.

## Decimation Registers

The forward and backward shifting registers are configurable for decimation by 1 to 16 (see Table 1). The backward shifting registers are used to take advantage of symmetry in linear phase filters by aligning data at the ALU's for pre-addition prior to multiplication by the common coefficient. When the FIR cells are configured in single filter mode, the decimation registers in each cell are cascaded. This lengthened delay path allows computation of a filter which is twice the size of that capable in a single cell. The decimation registers also provide data storage for poly-phase or 2-D filtering applications (See Applications Examples section).

The Data Feedback Circuitry in each FIR cell is responsible for transferring data from the forward to the backward shifting decimation registers. This circuitry feeds blocks of samples into the backward shifting decimation path in either reversed or non-reversed sample order. The MUX/DEMUX structure at the input to the Feedback Circuitry routes data to the LIFO's or the delay stage depending on configuration. The MUX on the Feedback Circuitry Output selects the storage element which feeds the backward shifting decimation registers.
In applications requiring reversal of sample order, such as FIR filtering with decimation, the FIR cells are configured with data reversal enabled (see Table 2). In this mode, data is transferred from the forward to the backward shifting registers through a ping-ponged LIFO structure. While one LIFO is being read into the backward shifting path, the other is written with data samples. The MUX/DEMUX controls which LIFO is being written, and the MUX on the Feedback Circuitry output controls which LIFO is being read. A low on TXFR\# and SHIFTEN\#, switches the LIFO's being read and written, which causes the block of data read from the structure to be reversed in sample order (See Example 4 in the Application Examples section).

The frequency with which TXFR\# is asserted determines size of the data blocks in which sample order is reversed. For example, if TXFR\# is asserted once every three CLK's, blocks of 3 data samples with order reversed, would be fed into the backward decimation registers. Note: altering the frequency or phase of TXFR\# assertion once a filtering operation has been started will cause unknown results.

In applications which do not require sample order reversal, the FIR cells must be configured with data reversal disabled (see Table 2). In addition, TXFR\# must be asserted to ensure proper data flow. In this configuration, data to the backward shifting decimation path is routed though a delay stage instead of the ping-pong LIFO's. The number of registers in the delay stage is based on the programmed decimation factor. Note: data reversal must be disabled and TXFR\# must be asserted for filtering applications which do not use decimation.

The shifting of data through the forward and reverse decimation registers is enabled by asserting the SHFTEN\# input. When SHFTEN\# transitions high, data shifting is disabled, and the data sample latched into the part on the previous clock is the last input to the forward decimation path. When SHFTEN\# is asserted, shifting of data through the decimation paths is enabled. The data sample at the part input when SHFTEN\# is asserted will be the next data sample into the forward decimation path.
When operating the FIR cells as two independent filters, FIR A receives input data via INAO-9 and FIR B receives data from either INAO-9 or INBO-9 depending on the configuration (Table 1). When the FIR cells are configured as a single extended length filter, the forward and backward decimation paths are cascaded. In this mode, data is transferred from the forward decimation path to the backward decimation path by the Data Feedback Circuitry in FIR B. Thus, the manner in which data is read into the backward shifting decimation path is determined by FIR B's configuration.

When the decimation paths are cascaded, data is routed through the delay stage in FIR A's Data Feedback Circuitry.
The configuration of the FIR cells as even or odd length filters determines the point in the forward decimation path from which data is multiplexed to the Data Feedback Circuitry. For example, if the FIR cell is configured as an odd length filter, data prior to the last register in the third forward decimation stage is routed to the Feedback Circuitry. If the FIR cell is configured as an even length filter, data output from the third forward decimation stage is multiplexed to the Feedback Circuitry. This is required to insure proper data alignment with symmetric filter coefficients (See Application Examples).

## ALUs

Data shifting through the forward and reverse decimation path feeds the " $a$ " and " $b$ " inputs of the ALUs respectively. The ALU's perform an " $b+a$ " operation if the FIR cell is configured for even symmetric coefficients or an "b-a" operation if configured for odd symmetric coefficients.

For applications in which a pre-add or subtract is not required, the " $a$ " or " $b$ " input can be zeroed by disabling FWRD\# or RVRS\# respectively. This has the effect of producing an ALU output which is either "a","-a", or "b" depending on the filter symmetry chosen. For example, if the FIR cell is configured for an even symmetric filter with FWRD\# low and RVRS\# high, the data shifting through the forward decimation registers would appear on the ALU output.

## Coefficient Bank

The output of the ALU is multiplied by a coefficient from one of 32 user programmable coefficient sets. Each set consists of 8 coefficients ( 4 coefficients for FIR A and 4 for FIR B). The active coefficient set is selected using CSELO-4. The coefficient set may be switched every clock to support polyphase filtering operations.
The coefficients are loaded into on-board registers using the microprocessor interface, CINO-9, AO-8, and WR\#. Each multiplier within the FIR Cells is driven by a coefficient bank with one of 32 coefficients. These coefficients are addressed as shown in Table 3. The inputs A0-1 specify the Coefficient Bank for one of the four multipliers in each FIR Cell; A2 specifies FIR Cell A or B; Bits A7-3 specify one of 32 sets in which the coefficient is to be stored. For example, an address of 10 dH would access the coefficient for the second multiplier in FIR B in the second coefficient set.

TABLE 3

| A8 | A7-3 | A2 | A1-0 | FIR | BANK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Xxxxx | 0 | 00 | A | 0 |
| 1 | $\underline{x x x x x}$ | 0 | 01 | A | 1 |
| 1 | x $x \times x \times x$ | 0 | 10 | A | 2 |
| 1 | $x \times x x x$ | 0 | 11 | A | 3 |
| 1 | xxxxx | 1 | 00 | B | 0 |
| 1 | x $x \times x \times x$ | 1 | 01 | B | 1 |
| 1 | xxxxx | 1 | 10 | B | 2 |
| 1 | xxxxx | 1 | 11 | B | 3 |

## FIR Cell Accumulator

The registered outputs from the multipliers in each FIR cell feed the FIR cell's accumulator. The ACCEN input controls each accumulator's running sum and the latching of data from the accumulator into the Output Holding Registers. When ACCEN is low, feedback from the accumulator adder is zeroed which disables accumulation. Also, output from the accumulator is latched into the Output Holding Registers. When ACCEN is asserted, accumulation is enabled and the contents of the Output Holding Registers remain unchanged.

## Output MUX/Adder

The contents of each FIR Cell's Output Holding Register is summed or multiplexed in the Mux/Adder. The operation of the Mux/Adder is controlled by the MUX1-0 inputs as shown in Table 4. Applications requiring 10 bit data and 20 bit coefficients or 20 bit data and 10 bit coefficients are made possible by configuring the MUX/Adder to scale FIR B's output by $\mathbf{2}^{-10}$ prior to summing with FIR A. When the Dual FIR is configured as two independent filters, the MUX1-O inputs would be used to multiplex the filter outputs of each cell. For applications in which FIR A and B are configured as a single filter, the MUX/Adder is configured to sum the output of each FIR cell.
table 4

| MUX1-O DECODING |  |
| :---: | :--- |
| MUX1-0 | OUTO-27 |
| 00 | FIRA + FIRB (FIR B Scaled by 2-10) |
| 01 | FIRA + FIRB |
| 10 | FIRA |
| 11 | FIRB |

## Input/Output Formats

The Dual FIR supports mixed mode arithmetic with both unsigned and two's complement data and coefficients. The input and output formats for both data types is shown below. If the Dual FIR is configured as an even symmetric filter with unsigned data and coefficients, the output will be unsigned. Otherwise, the output will be two's complement.

INPUT DATA FORMAT INAO-9, INBO-9 FRACTIONAL TWO'S COMPLEMENT

| 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{0}$ | $.2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ |

OUTPUT DATA FORMAT OUT9-27
FRACTIONAL TWO'S COMPLEMENT


OUTPUT DATA FORMAT OUTO-8 FRACTIONAL TWO'S COMPLEMENT
 FRACTIONAL UNSIGNED

| 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ |

OUTPUT DATA FORMAT OUT9-27
FRACTIONAL UNSIGNED


OUTPUT DATA FORMAT OUTO-8 FRACTIONAL UNSIGNED

| 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ | $2^{-16}$ | $2^{-17}$ | $2^{-18}$ |

The MUX/Adder can be configured to implement programmable rounding at bit locations $2^{-10}$ through $2^{1}$. The round is implemented by adding a 1 to the specified location (see Table 2.0). For example, to configure the part such that the output is rounded to the 10 MSBs , OUT18-27, the round position would be chosen to be 2-1.

## Application Examples

In this section a number of examples which show even, odd, symmetric, asymmetric and decimating filters are presented. These examples are intended to show different operational modes of the HSP43168. The examples are all based on a dual filter configuration. However, the same principles apply when the part is configured with both FIR cells operating as a single filter.

## Example 1. Even-Tap Symmetric Filter Example

The HSP43168 may be configured as two independent 8tap symmetric filters as shown by the block diagram in Figure 2. Each of the FIR cells takes advantage of symmetric filter coefficients by pre-adding data samples common to a given coefficient. As a result, each FIR cell can implement an 8-tap symmetric filter using only four multipliers. Similarly, when the HSP43168 is configured in single filter mode a 16-tap symmetric filter is possible by using the multipliers in both cells.
The operation of the FIR cell is better understood by comparing the data and coefficient alignment for a given filter output, Figure 3, with the data flow through the FIR cell, as shown in Figure 4. The block diagrams in Figure 4 are a simplification of the FIR cell shown in Figure 1. For simplicity, the ALU's and FIR Cell Accumulators were replaced by adders, and the pipeline delay registers were omitted.


FIGURE 2. USING HSP43168 AS TWO INDEPENDENT FILTERS

In Figure 4, the order of the data samples within the filter cell is shown by the numbers in the forward and backward shifting decimation paths. The output of the filter cell is given by the equation at the bottom of each block diagram. Figure 4 a shows the data sample alignment at the pre-adders for the data/coefficient alignment shown in Figure 3.


FIGURE 3. DATA/COEFFICIENT ALIGNMENT FOR 8-TAP EVEN SYMMETRIC FILTER

The dual filter application is configured by writing 1 dOH to address 000 H via the microprocessor interface, $\mathrm{CINO}-9$, A0-8, and WR\#. Since this application does not use decimation, the 4 th bit of the control register at address 001 H must be set to disable data reversal (see Table 2). Failure to disable data reversal will produce erroneous results.
A. DATA FLOW AS DATA SAMPLE 7 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 7+X 0) C 0+(X 6+X 1) C 1+(X 5+X 2) C 2+(X 4+X 3) C 3$
B. DATA FLOW AS DATA SAMPLE 8 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 8+X 1) C 0+(X 7+X 2) C 1+(X 6+X 3) C 2+(X 5+X 4) C 3$
C. DATA FLOW AS DATA SAMPLE 9 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 9+X 2) \mathrm{C} 0+(\mathrm{X} 8+\mathrm{X} 3) \mathrm{C} 1+(\mathrm{X} 7+\mathrm{X} 4) \mathrm{C} 2+(\mathrm{X} 6+\mathrm{X} 5) \mathrm{C} 3$

FIGURE 4. DATA FLOW DIAGRAMS FOR 8-TAP SYMMETRIC FILTER

Using this architecture, only the unique coefficients need to be stored in the Coefficient Bank. For example, the above filter would be stored in the first coefficient set for FIR A by writing C0, C1, C2, and C3 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}$, and 103 H respectively. To write the same filter to the first coefficient set for FIR B, the address sequence would change to $104 \mathrm{H}, 105 \mathrm{H}, 106 \mathrm{H}$, and 107 H .

To operate the HSP43168 in this mode, TXFR\# is tied low to ensure proper data flow; both FWRD\# and RVRS\# are tied low to enable data samples from the forward and reverse data paths to the ALU's for pre-adding; ACCEN is tied low to prevent accumulation over multiple CLK's; SHFTEN\# is tied low to allow shifting of data through the decimation registers; MUXO-1 is programmed to multiplex the output the of either FIR A or FIR B; CSELO-4 is programmable to access the stored coefficient set, in this example CSEL $=00000$.

## Example 2. Odd-Tap Symmetric Filter Example

The HSP43168 may be configured as two independent 7-tap symmetric filters with a functional block diagram resembling Figure 2. As in the 8-tap filter example, the HSP43168 implements the filtering operation by summing data samples sharing a common coefficient prior to multiplication by that coefficient. However, for odd length filters the pre-addition requires that the center coefficient be scaled by $1 / 2$.

The operation of the FIR cell for odd length filters is better understood by comparing the data/coefficient alignment in Figure 5 with the data flow diagrams in Figure 6. The block diagrams in Figure 6 are a simplification of the FIR cell shown in Figure 1.



FIGURE 5. DATA/COEFFICIENT ALIGNMENT FOR 7-TAP SYMMETRIC FILTER

For odd length filters, proper data/coefficient alignment is ensured by routing data entering the last register in the third forward decimation stage to the backward shifting registers. In this configuration, the center coefficient must be scaled by $1 / 2$ to compensate for the summation of the same data sample from both the forward and backward shifting registers.
A. DATA FLOW AS DATA SAMPLE 6 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 6+X 0) C 0+(X 5+X 1) C 1+(X 4+X 2) C 2+(X 3+X 3) C 3 / 2$
B. DATA FLOW AS DATA SAMPLE 7 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 7+X 1) C 0+(X 6+X 2) C 1+(X 5+X 3) C 2+(X 4+X 4) C 3 / 2$
C. DATA FLOW AS DATA SAMPLE 8 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 8+X 2) C 0+(X 7+X 3) C 1+(X 6+X 4) C 2+(X 5+X 5) C 3 / 2$
FIGURE 6. DATA FLOW DIAGRAMS FOR 7-TAP SYMMETRIC FILTER.

In the data flow diagrams of Figure 6, the order of the data samples input in to the filter cell is shown by the numbers in the forward and backward shifting decimation paths. The output of the filter cell is given by the equation at the bottom of the block. The diagram in Figure 6a shows data sample alignment at the pre-adders for the data/coefficient alignment shown in Figure 5.

This dual filter application is configured by writing 110 H to address 000 H via the microprocessor interface, CINO-9, A0-8, and WR\#. Also, data reversal must be disabled by setting bit 4 of the control register at address 0001 H . As in the 8-tap example, only the unique coefficients need to be stored in the Coefficient Bank. These coefficients are stored in the first coefficient set for FIR A by writing $\mathrm{CO}, \mathrm{C} 1, \mathrm{C} 2$, and C 3 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}$, and 103 H respectively. To write the same filter to the first coefficient set for FIR B, the address sequence would change to $104 \mathrm{H}, 105 \mathrm{H}$, 106 H , and 107 H . The control signals TXFR\#, FWRD\#, RVRS\#, ACCEN, SHFTEN\#, and CSELO-4 are controlled as described in Example 1.

## Example 3. Asymmetric Filter Example

The FIR cells within the HSP43168 can each calculate 4 asymmetric taps on each clock. Thus, a single FIR cell can implement an 8-tap asymmetric filter if the HSP43168 is clocked at twice the input data rate. Similarly, if the Dual is configured as a single filter, a 16- tap asymmetric filter is realizable.

For this example, the FIR cells are configured as two 8- tap asymmetric filters which are clocked at twice the input data rate. New data is shifted into the forward and backward decimation paths every other CLK by the assertion of SHFTEN\#. The filter output is computed by passing data from each decimation path to the multipliers on alternating clocks. Two sets of coefficients are required, one for data on the forward decimation path, and one for data on the reverse path. The filter output is generated by accumulating the multiplier outputs for two CLKs.

The operation of this configuration is better understood by comparing the data/coefficient alignment in Figure 7 with the data flow diagrams in Figure 8. The ALU's have been omitted from the FIR cell diagrams because data is fed to the multipliers directly from the forward and reverse decimation paths. The data samples within the FIR cell are shown by the numbers in the decimation paths.
$h(n)$

$x(n)$


FIGURE 7. DATA/COEFFICIENT ALIGNMENT FOR 8-TAP ASYMMETRIC FILTER
A. DATA SHIFTING DISABLED, BACKWARD SHIFTING
DECIMATION REGISTERS FEEDING MULTIPLIERS.

B. SHIFTING OF DATA SAMPLE 7 INTO FIR CELL ENABLED, FORWARD SHIFTING REGISTERS FEEDING MULTIPLIERS.

(X0)CO+(X1)C1+(X2)C2+(X3)C3 $+(X 7) \mathrm{C} 7+(\mathrm{X} 6) \mathrm{C} 6+(\mathrm{X} 5) \mathrm{C} 5+(\mathrm{X} 4) \mathrm{C} 4$
C. DATA SHIFTING DISABLED, BACKWARD SHIFTING DECIMATION REGISTERS FEEDING MULTIPLIERS.

(X1)C0+(X2)C1+(X3)C2+(X4)C3

FIGURE 8. DATA FLOW DIAGRAMS FOR 8-TAP ASYMMETRIC FILTER

## D. SHIFTING OF DATA SAMPLE 8 INTO FIR CELL ENABLED, FORWARD SHIFTING REGISTERS FEEDING MULTIPLIERS



FIGURE 8. DATA FLOW DIAGRAMS FOR 8-TAP ASYMMETRIC FILTER CONTINUED

For this application, each filter cell is configured as an odd length filter by writing 110 H to the control register at address 000 H . Even though an even tap filter is being implemented, the filter cells must be configured as odd length to ensure proper data flow. Also, the 4th bit at control address 001 H must be set to disable data reversal, and TXFR\# must be tied low. Since an 8-tap asymmetric filter is being implemented, two sets of coefficients must be stored. These eight coefficients could be loaded into the first two coefficient sets for FIR A by writing $\mathrm{CO}, \mathrm{C} 1, \mathrm{C} 2, \mathrm{C} 3, \mathrm{C} 7, \mathrm{C} 6, \mathrm{C} 5$, and C 4 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}, 103 \mathrm{H}, 108 \mathrm{H}, 109 \mathrm{H}, 10 \mathrm{aH}$, and 10 bH respectively.

The sum of products required for this 8-tap filter require $d y$ namic control over FWRD\#, RVRS\#, ACCEN, and CSELO4. The relative timing of these signals is shown in Figure 9.


FIGURE 9. CONTROL TIMING FOR 8-TAP ASYMMETRIC FILTER

## Example 4. Even-Tap Decimating Filter Example

The HSP43168 supports filtering applications requiring decimation to 16. In these applications the output data rate is reduced by a factor of $\mathbf{N}$. As a result, N clock cycles can be used for the computation of the filter output. For example, each FIR cell can calculate 8 symmetric or 4 asymmetric taps in one clock. If the application requires decimation by two, the filter output can be calculated over two clocks thus boosting the number of taps per FIR cell to 16 symmetric or 8 asymmetric. For this example, each FIR cell is configured as an independent 24-tap decimate x3 filter.

The alignment of data relative to the 24 filter coefficients for a particular output is depicted graphically in Figure 10. As in previous examples, the HSP43168 implements the filtering operation by summing data samples prior to multiplication by the common coefficient. In this example an output is required every third CLK which allows 3 CLK's for computation. On each CLK, one of three sets of coefficients are used to calculate 8 of the filter taps. The block diagrams in Figure 12 show the data flow and accumulator output for the data/ coefficient alignment in Figure 10.


FIGURE 10. DATA/COEFFICIENT ALIGNMENT FOR 24-TAP DECIMATE BY 3 FIR FILTER

Proper data and coefficient alignment is achieved by asserting TXFR\# once every three CLK's to switch the LIFO's which are being read and written. This has the effect of feeding blocks of three samples into the backward shifting decimation path which are reversed in sample order. In addition, ACCEN is de-asserted once every three clocks to allow accumulation over three CLK's. The three sets of coefficients required in the calculation of a 24-tap symmetric filter are cycled through using CSELO-4. The timing relationship between the CSELO-4, ACCEN, and TXFR\# are shown in Figure 12.

$(X 2+X 21) C 2+(X 5+X 18) C 5+(X 8+X 15) C 8+(X 11+X 12) C 11$
B. COMPUTATIONAL FLOW AS DATA SAMPLE 22 IS CLOCKED INTO THE FEED FORWARD STAGE

C. COMPUTATIONAL FLOW AS DATA SAMPLE 23 IS CLOCKED INTO THE FEED FORWARD STAGE


To operate in this mode the Dual is configured by writing 1d2 to address 000 H via the microprocessor interface, CINO-9, AO-8, and WR\#. Data reversal must be enabled see (Table 2.0). The 12 unique coefficients for this example are stored as three sets of coefficients for either FIR cell. For FIR A, the coefficients are loaded into the Coefficient Bank by writing C2, C5, C8, C11, C1, C4, C7, C10, C0, C3, C6, and C 9 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}, 103 \mathrm{H}, 108 \mathrm{H}, 109 \mathrm{H}$, $10 \mathrm{aH}, 10 \mathrm{bH}, 110 \mathrm{H}, 111 \mathrm{H}, 112 \mathrm{H}$, and 113 H respectively.

## D. COMPUTATIONAL FLOW AS DATA SAMPLE 24 IS

 CLOCKED INTO THE FEED FORWARD STAGE

FIGURE 11. DATA FLOW DIAGRAMS FOR 24-TAP DECIMATE BY 3 FIR FILTER


FIGURE 12. CONTROL SIGNAL TIMING FOR 24-TAP DECIMATE X3 FILTER

## Example 5. Odd-Tap Decimating Symmetric Filter

This example highlights the use of the HSP43168 as two independent, 23-tap, symmetric, decimate by 3 filters. In this example, the operational differences in the control signals and data reversal structure may be compared to the previously discussed even-tap decimating filter.

As in the 24-tap example, an output is required every third CLK which allows 3 CLK's for computation. On each CLK, one of three sets of coefficients are used to caiculate the filter taps. Since this is an odd length filter, the center coefficient must be scaled by $1 / 2$ to compensate for the summation of the same data sample from the forward and backward shifting decimation paths. The block diagrams in Figure 14 show the data flow and accumulator output for the data coefficient alignment in Figure 13.

Proper data and coefficient alignment is achieved by asserting TXFR\# once every three CLK's to switch the LIFO's which are being read and written. For odd length filters, data prior to the last register in the forward decimation path is routed to the Feedback Circuitry. As a result, TXFR\# should be asserted one cycle prior to the input data samples which align with the center tap. The timing relationship between the CSELO-5, ACCEN, and TXFR\# are shown in Figure 15.


FIGURE 13. DATA/COEFFICIENT ALIGNMENT FOR 23-TAP DECIMATE BY 3 SYMMETRIC FILTER

$(X 2+X 20) C_{2}+(X 5+X 17) C 5+(X 8+X 14) C 8+(X 11+X 11) C_{11 / 2}$
A. COMPUTATIONAL FLOW AS DATA SAMPLE 20 IS CLOCKED INTO THE FEED FORWARD STAGE

B. COMPUTATIONAL FLOW AS DATA SAMPLE 21 IS CLOCKED INTO THE FEED FORWARD STAGE

(X0 +X 22 ) $\mathrm{CO}+(\mathrm{X} 3+\mathrm{X} 19) \mathrm{C} 3+(X 6+X 16) \mathrm{C} 6+(X 9+X 13) \mathrm{Cs}$ $+(X 1+X 21) C 1+(X 4+X 18) C 4+(X 7+X 15) C 7+(X 10+X 12) C 10$ $+(X 2+X 20) \mathrm{C} 2+(X 5+X 17) \mathrm{C} 5+(X 8+X 14) \mathrm{C} 8+(X 11+X 11) \mathrm{C} 11 / 2$
D. COMPUTATIONAL FLOW AS DATA SAMPLE 23 IS CLOCKED INTO THE FEED FORWARD STAGE

$(X 5+X 23) \mathrm{C} 2+(X 8+X 20) \mathrm{C} 5+(X 11+X 17) \mathrm{C} 8+(X 14+X 14) \mathrm{C} 11 / 2$

FIGURE 14. DATA FLOW DIAGRAMS FOR 23-TAP DECIMATE BY 3 SYMMETRIC FILTER


FIGURE 15. CONTROL SIGNAL TIMING FOR 23-TAP SYMMETRIC FILTER

To operate in this mode, the Dual is configured by writing 112 H to address 000 H via the microprocessor interface, CINO-9, AO-8, and WR\#. Data reversal must be enabled (see Table 2.0). The 12 unique coefficients for this example are stored as three sets of coefficients for either FIR cell. For FIR A, the coefficients are loaded into the Coefficient Bank by writing C2, C5, C8, (C11)/ 2, C1, C4, C7, C10, C0, C3, C , and C 9 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}, 103 \mathrm{H}, 108 \mathrm{H}$, $109 \mathrm{H}, 10 \mathrm{aH}, 10 \mathrm{bH}, 110 \mathrm{H}, 111 \mathrm{H}, 112 \mathrm{H}$, and 113 H respectively.

## Absolute Maximum Ratings

| Supply Voltage | 8.0 V |
| :---: | :---: |
| Input, Output Voltage | . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature. | . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD | Class 1 |
| Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ | 2.4W (MQFP), 3.6W (PLCC), 3.1W (PGA) |
| $\theta_{\text {jc }}$ | $13.5{ }^{\circ} \mathrm{C} / \mathrm{W}$ (MQFP), $7.4^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $7.5^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| $\theta_{\text {ja }}$ | $33.0^{\circ} \mathrm{C} / \mathrm{W}$ (MQFP), $22.3^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $33.5^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Gate Count | 32529 |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ (PGA),$+150^{\circ} \mathrm{C}$ (PLCC) |
| Lead Temperature (Soldering 10s) | $\ldots+300^{\circ} \mathrm{C}$ |
| CAUTION: Stresses above those listed in the "Absolute operation of the device at these or any other condition | e permanent damage to the device. This is a stress only rating and he operational sections of this specification is not implied. |

## Operating Conditions

```
Operating Voltage Range, Commercial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5V \ 5% 
Operating Temperature Range
    Commercial
    .0}\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+7\mp@subsup{0}{}{\circ}\textrm{C
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 363 | mA | $v_{C C}=\operatorname{Max}$ <br> CLK Frequency 33 MHz Note 2, Note 3, Note 4 |
| ICCSB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Outputs Not Loaded |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |
| $\mathrm{V}_{\mathrm{lL}}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\text {CC }}=$ Min |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \theta \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=$ Max |
| VILC | Clock input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{ClN}^{\text {N }}$ | Input Capacitance | - | 12 | pF | CLK Frequency 1 MHz All measurements referenced |
| Cout | Output Capacitance | - | 12 | pF | to GND. $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \text { Note } 1$ |

## NOTES:

1. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
2. Power Supply current is proportional to operating frequency. Typical rating for $\mathrm{I}_{\mathrm{CCOP}}$ is $11 \mathrm{~mA} / \mathrm{MHz}$.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
4. Maximum junction temperature must be considered when operating part at high clock frequencies.

## A.C. Electrical Specificatlons $\mathrm{V}_{\mathrm{CC}}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1 )

| SYMBOL | PARAMETER | 33 MHz |  | 45MHz |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| TCP | CLK Period | 30 | - | 22 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | CLK High | 12 | - | 8 | - | ns |
| TCL | CLK Low | 12 | - | 8 | - | ns |
| TWP | WR\# Period | 30 | - | 22 | - | ns |
| TWH | WR\# High | 12 | - | 10 | - | ns |
| TWL | WR\# Low | 12 | - | 10 | - | ns |
| $\mathrm{T}_{\text {AWS }}$ | Set-up Time AO-8 to WR\# Going Low | 10 | - | 8 | - | ns |
| TAWH | Hold Time AO-8 from WR\# Going High | 0 | - | 0 | - | ns |
| TCWs | Set-up Time CINO-9 to WR\# Going High | 12 | - | 10 | - | ns |
| TCWH | Hold Time CINO-9 from WR\# Going High | 1 | - | 1 | - | ns |
| TWLCL | Set-up Time WR\# Low to CLK Low | 5 | - | 3 | - | ns, Note 2 |
| TCVCL | Set-up Time CINO-9 to CLK Low | 7 | - | 7 | - | ns, Note 2 |
| TECS | Set-up Time CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, INAO-9, INBO-9, ACCEN, MUXO-1 to CLK Going High | 15 | - | 12 | - | ns |
| TECH | Hold Time CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, INAO-9, INBO-9, ACCEN, MUXO-1 to CLK Going High | 0 | - | 0 | - | ns |
| TDO | CLK to Output Delay OUT0-27 | - | 14 | - | 12 | ns |
| TOE | Output Enable Time | - | 12 | - | 12 | ns |
| TOD | Output Disable Time | - | 12 | - | 12 | ns, Note 3 |
| TRF | Output Rise, Fall Time | - | 6 | - | 6 | ns, Note 3 |

NOTES:

1. AC tests performed with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}, \mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$, and $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$. Input reference level CLK $=2.0 \mathrm{~V}$. Input reference level for all other inputs is 1.5 V . Test $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{ILC}}=0 \mathrm{~V}$.
2. Set-up time requirement for loading of data on CINO-9 to guarantee recognition on the following clock.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.

## A.C. Test Load Circuit



Waveforms


OEL \#, OEH \#

OUTO-27


OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES

## Features

- This Circult is Processed in Accordance to MiL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Two Independent 8-Tap FiR Filters Configurable as a Single 16-Tap FIR
- 10-Bit Data \& Coefficients
- On-Board Storage for 32 Programmable Coefficient Sets
- Up To: 256 FIR Taps, $16 \times 16$ 2-D Kernels, or $10 \times 20$-Bit Data and Coefficients
- Programmable Decimation to 16
- Programmable Rounding on Output
- Standard Microprocessor Interface
- 33MHz, 25.6MHz Versions


## Applications

- Quadrature, Complex Filtering
- Correlation
- Image Processing
- PolyPhase Filtering
- Adaptive Filtering


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP43168GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |
| $\mathrm{HSP} 43168 \mathrm{GM}-33 / 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The HSP43168 Dual FIR Filter consists of two independent 8 -tap FIR filters. Each filter supports decimation from 1 to 16 and provides on-board storage for 32 sets of coefficients. The Block Diagram shows two FIR cells each fed by a separate coefficient bank and one of two separate inputs. The outputs of the FIR cells are either summed or multiplexed by the MUX/Adder. The compute power in the FIR Cells can be configured to provide quadrature filtering, complex filtering, 2-D convolution, 1-D/2-D correlations, and interpolating/decimating filters.

The FIR cells take advantage of symmetry in FIR coefficients by pre-adding data samples prior to multiplication. This allows an 8-tap FIR to be implemented using only 4 multipliers per filter cell. These cells can be configured as either a single 16 -tap FIR filter or dual 8 -tap FIR filters. Asymmetric filtering is also supported.

Decimation of up to 16 is provided to boost the effective number of filter taps from 2 to 16 times. Further, the decimation registers provide the delay necessary for fractional data conversion and 2-D filtering with kernels to $16 \times 16$.

The flexibility of the Dual is further enhanced by 32 sets of user programmable coefficients. Coefficient selection may be changed asynchronously from clock to clock. The ability to toggle between coefficient sets further simplifies applications such as polyphase or adaptive filtering.

The HSP43168 is a low power fully static design implemented in an advanced CMOS process. The configuration of the device is controlled through a standard microprocessor interface.

## Block Diagram



## Pinouts



## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {JA }}$ | ${ }^{\theta} \mathrm{Jc}$ |
| :---: | :---: | :---: |
| Ceramic PGA Packag | $33.5{ }^{\circ} \mathrm{C} / \mathrm{N}$ | $7.5^{\circ} \mathrm{C} / \mathrm{W}$ |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions


TABLE 1. DC ELECTRICAL. PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | $\begin{aligned} & \text { GROUP A } \\ & \text { SUB- } \\ & \text { GROUPS } \end{aligned}$ | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | v |
| Logical Zero Input Voltage Clock | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW <br> Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | $\mathrm{I}_{\text {ccss }}$ | $\begin{aligned} & V_{\mathbb{I N}}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=25.6 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \\ & \text { or GND, } \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 281.6 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $11 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 2. AC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | $\begin{aligned} & \text { GROUP A } \\ & \text { SUB- } \\ & \text { GROUPS } \end{aligned}$ | TEMPERATURE | (-33MHz) |  | (-25MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | $T_{C P}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | $\bullet$ | 39 | - | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| WR\# Period | $\mathrm{T}_{\text {WP }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 39 | - | ns |
| WR\# High | $\mathrm{T}_{\text {WH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| WR\# Low | $T_{W}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| Set-up Time; AO-8 to WR\# Low | TAWs |  | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 10 | - | ns |
| Hold Time; A0-8 to WR\# High | $\mathrm{T}_{\text {AWH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Set-up Time; CINO-9 to WR\# High | $\mathrm{T}_{\text {cws }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| Hold Time; CINO-9 to WR\# High | T ${ }_{\text {CWH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1.5 | - | 1.5 | - | ns |
| Set-up Time; WR\# Low to CLK Low | TWLCL | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 8 | - | ns |
| Set-up Time; CINO-9 to CLK Low | $\mathrm{T}_{\text {cvCL }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 8 | - | 8 | - | ns |
| Set-up Time; CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUX0-1 to CLK High | $T_{\text {ECS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 17 | - | ns |
| Hold Time; CSEL0-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUX0-1 to CLK High | $\mathrm{T}_{\text {ECH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Output Delay OUT0-27 | $T_{\text {D }}$ |  | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 15 | - | 17 | ns |
| Output Enable Time | ToE | Note 2 | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 12 | - | 12 | ns |

NOTES:

1. AC testing is performed as follows: Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 3.0 V and 0 V ; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $V_{\mathrm{OH}}>1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}}<1.5 \mathrm{~V}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Set-up time requirements for loading of data on CINO-9 to guarantee recognition on the following clock.

Specifications HSP43168/883
TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | (-33MHz) |  | (-25MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{1 \mathrm{~N}}$ | $\mathrm{V}_{\mathrm{cc}}=\text { Open, } \mathrm{f}=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Capacitance | Cout |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Disable Time | TOD |  | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 12 | - | 12 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

NOTE:

1. The parameters in Table 3 are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples/5005 | $1,7,9$ |

## AC Test Load Circuit



Waveforms


OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES

## HSP43168/883

## Burn-In Circuit

> 84 PIN PGA BOTTOM VIEW


NOTES:

1. $\mathrm{V}_{\mathrm{C}}{ }^{2}(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$
4. $0.1 \mu \mathrm{f}$ (Min) capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $F 0=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 . ., F 16=F 15 / 2$, 40 to $60 \%$ duty cycle.
6. Input voltage limits:
$\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \mathrm{Max}, \mathrm{V}_{\mathrm{IH}}=4.5 \pm 10 \%$

| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| A1 | CIN8 | F9 |
| A2 | CSEL4 | F12 |
| A3 | CSEL3 | F11 |
| A4 | CSEL1 | F9 |
| A5 | A8 | F12 |
| A6 | A7 | F10 |
| A7 | A4 | F11 |
| A8 | A1 | F12 |
| A9 | GND | GND |
| A10 | WRB | F6 |
| A11 | RVRS | F12 |
| B1 | CIN5 | F8 |
| B2 | CIN7 | F10 |
| B3 | CIN9 | F10 |
| B4 | CSEL2 | F10 |
| B5 | VCC | $V_{C C}$ |
| B6 | A2 | F11 |
| B7 | A3 | F10 |
| B8 | A0 | F13 |
| B9 | MUX1 | F13 |
| B10 | MUX0 | F12 |


| $\begin{array}{\|l} \hline \text { PGA } \\ \text { PIN } \end{array}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | $\begin{aligned} & \text { BURN-IN } \\ & \text { SIGNAL } \end{aligned}$ |
| :---: | :---: | :---: |
| B11 | SHFTEN | F14 |
| C1 | CIN4 | F7 |
| C2 | CIN6 | F9 |
| C5 | CSELO | F8 |
| C6 | Á6 | F11 |
| C7 | A5 | F12 |
| C10 | FWRD | F13 |
| C11 | TXFR | F11 |
| D1 | CIN3 | F10 |
| D2 | GND | GND |
| D10 | ACCEN | F13 |
| D11 | $V_{C c}$ | $V_{\text {cc }}$ |
| E1 | CINO | F7 |
| E2 | CIN1 | F8 |
| E3 | CIN2 | F9 |
| E9 | CLK | F0 |
| E10 | GND | GND |
| E11 | OEHB | F14 |
| F1 | $V_{\text {cc }}$ | $V_{\text {cc }}$ |
| F2 | INA9 | F10 |
| F3 | INA8 | F9 |


| $\begin{array}{\|l\|} \hline \text { PGA } \\ \text { PIN } \end{array}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| F9 | SUM26 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| F10 | SUM22 | $V_{c}{ }^{2} 2$ |
| F11 | SUM27 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| G1 | INA6 | F7 |
| G2 | INA5 | F6 |
| G3 | INA7 | F8 |
| G9 | SUM25 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| G10 | SUM23 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| G11 | SUM24 | $\mathrm{V}_{\mathrm{cd}}{ }^{2}$ |
| H1 | INA4 | F5 |
| H2 | INA3 | F4 |
| H10 | SUM20 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| H11 | SUM21 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| J1 | INA2 | F3 |
| J2 | INAO | F1 |
| J5 | INB3 | F4 |
| J6 | OELB | F13 |
| J7 | SUM9 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| J10 | SUM17 | $\mathrm{V}_{\mathrm{c}}{ }^{12}$ |
| J11 | SUM19 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| K1 | INA1 | F2 |


| $\begin{aligned} & \hline \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| K2 | 1NB8 | F9 |
| K3 | INB7 | F8 |
| K4 | GND | GND |
| K5 | INB2 | F3 |
| K6 | INB0 | F1 |
| K7 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\text {cc }}$ |
| K8 | SUM13 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| K9 | SUM16 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| K10 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| K11 | SUM18 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| L1 | INB9 | F10 |
| L2 | INB6 | F7 |
| L3 | INB5 | F6 |
| L4 | INB4 | F5 |
| L5 | INB1 | F2 |
| L6 | SUM11 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| L7 | SUM10 | $\mathrm{V}_{\mathrm{c} \mathrm{d}^{2}}$ |
| L8 | SUM12 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| L9 | SUM14 | $\mathrm{V}_{\mathrm{c}}{ }^{\text {2 }}$ |
| L10 | SUM15 | $\mathrm{V}_{\mathrm{c}} \mathrm{d}^{2}$ |
| L11 | GND | GND |

## Metallization Topology

DIE DIMENSIONS:
$314 \times 348 \times 19 \pm$ 1mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k

GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY:
$1.93 \times 10^{5} \mathrm{Acm}^{2}$

## Metallization Mask Layout

## HSP43168/883



Halfband Filter

## Features

- Sample Rates to 52 MSPS
- Architected to Support Sample Rates to 104 MSPS Using External Multiplexer
- Four Modes of Operation:
- Interpolate by 2 Filtering
- Decimate by 2 Filtering
- Quadrature to Real Signal Conversion
- Fs/4 Quadrature Down Conversion Followed by Decimate by 2 Filtering
- 67 Halfband FIR Filter with 20-Bit Coefficients
- 1.24:1 Fliter Shape Factor, $>90 \mathrm{~dB}$ Stopband Attenuation, <0.0003dB Passband Ripple
- Two's Complement or Offset Binary Outputs
- Programmable Rounding on Outputs


## Applications

- Digital Down Conversion
- D/A and AD pre/post Filtering
- Tuning Bandwidth Expansion for HSP45116 and HSP45106


## Description

The HSP43216 Halfband Filter addresses a wide variety of applications by combining $F_{S} / 4$ ( $F_{S}=$ sample frequency) quadrature up/down convert circuitry with a fixed coefficient halfband filter processor as shown in the block diagram. These elements may be configured to operate in one of the four following modes: decimate by 2 filtering of a real input signal; interpolate by 2 filtering of a real input signal; $\mathrm{F}_{\mathrm{S}} / 4$ quadrature down conversion of a real input signal followed by decimate-by-2 filtering to produce a complex analytic signal; interpolate-by-2 filtering of a complex analytic signal followed by $\mathrm{F}_{\mathrm{S}} / 4$ quadrature up conversion to produce a real valued output.

The frequency response of the HSP43216's halfband filter has a shape factor, (passband+transition band)/passband, of $1.24: 1$ with 90 dB of stopband attenuation. The passband has less than 0.0003 dB of ripple from $0 \mathrm{~F}_{\mathrm{S}}$ to $0.2 \mathrm{~F}_{\mathrm{S}}$ with stopband attenuation of greater than 90 dB from $0.3 \mathrm{~F}_{\mathrm{S}}$ to Nyquist. At $0.25 \mathrm{~F}_{\mathrm{S}}$ the filter provides 6 dB of attenuation.

The HSP43216 processes data streams with word widths up to 16 -bits and data rates up to 52 MSPS. The processing through put of the part is easily doubled to rates of up to 104 MSPS by using the part together with an external multiplexer or demultiplexer. Programmable rounding is provided to support output precisions from 8 -bits to 16 -bits.

## Ordering Information

| PART <br> NUMBER | TEMPERATURE <br> RANGE | PACKAGE <br> TYPE |
| :---: | :---: | :---: |
| HSP43216GC-52 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43216JC-52 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |

## Block Diagram



## Pinouts



## Pinouts (Continued)



Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| Vcc | 11, 36, 72 | - | +5V Power |
| GND | 9, 35, 47, 59, 71 | - | Ground |
| CLK | 10 | 1 | Clock Input. (CMOS LEVEL) |
| AINO-15 | 75-84, 1-6 | 1 | Input Data Bus A. AINO is the LSB. Input data format is 16 -bit Two's Complement. |
| BINO-15 | 15-30 | 1 | Input Data Bus B. BINO is the LSB. Input data format is 16 -bit Two's Complement. |
| MODE0-1 | 7, 8 | 1 | The Mode Select Inputs set one of four operational modes as highlighted in Table 1. |
| INT/EXT\# | 14 | 1 | The InternaNExternal multiplexer select inputs set whether the data multiplex/demultiplex function required in the various operational modes is performed internally (High State) or externally to the chip (Low State). |
| SYNC\# | 12 | 1 | This input is used to synchronize the input sample stream with the zero degree phase of the up or down convert Local Oscillators. In the straight decimate modes, this input can be use to synchronize the input sample stream with a particular phase of the halfband filter. (See the Operational Modes Section for additional information) |
| USB/LSB\# | 13 | 1 | The Upper and Lower Sideband select line is used to specify the direction of frequency translation imparted on the data stream in the Up Convert and Quadrature to Real Convert Modes. (See Operational Modes Section for additional information) |
| RNDO-2 | 31-33 | 1 | The Round Select inputs set the number of output bits from eight ( $\mathrm{RND}=000$ ) to sixteen (RND=110). Least significant output bits are zeroed. See Table 4. |
| OEA\# | 73 | 1 | Three State Control Output Bus A, OUTA0-15. Active Low. |
| OEB\# | 34 | 1 | Three State Control Output Bus B, OUTB0-15. Active Low. |
| FMT | 74 | 1 | The Format select input is used to convert the two's complement output to offset binary (unsigned). When asserted high, the AOUT15 and BOUT15-bits are inverted from the normal two's complement representation. |
| AOUTO-15 | 54-58, 60-70 | 0 | Output Bus A. AOUTO is the LSB. |
| BOUTO-15 | 37-46, 48-53 | 0 | Output Bus B. BOUT0 is the LSB. |



## Functional Description

The operation of the HSP43216 centers around a fixed coefficient, 67-Tap, Halfband Filter Processor as shown in Figure 1. The Halfband Filter Processor operates stand alone to provide two fundamental modes of operation, interpolate or decimate by two filtering of a real signal. In two other modes, the Quadrature Up/Down Convert circuitry operates together with the Filter Processor block to provide $\mathrm{F}_{\mathrm{S}} / 4$ Down Conversion with decimate by 2 filtering or Quadrature to Real Conversion.

In Down Convert and Decimate mode, a real input sample stream is spectrally shifted by $\mathrm{F}_{\mathbb{S}} / 4$. Each component of the resulting complex signal is then halfband filtered and decimated by 2 to produce real and imaginary output samples at half of the input data rate.

In Quadrature to Real Conversion mode, the real and imaginary components of a quadrature input are interpolated by two and halfband filtered. The filtered result is then spectrally shifted by $F_{S} / 4$ and the real component of this operation is output at twice the input sample rate. The HSP43216 is configured for different operational modes by setting the state of the mode control pins, MODE1-0 as shown in Table 1.

TABLE 1. MODE SELECT TABLE

| MODE1-0 | MODE |
| :---: | :--- |
| 00 | Decimate by Two |
| 01 | Interpolate by Two |
| 10 | Down Convert and Decimate |
| 11 | Quadrature to Real Conversion |

## Input Data Flow Controller

The Input Data Flow Controller routes data samples from the AINO-15 and BINO-15 inputs to the internal processing elements of the Halfband. The data routing paths are based on mode of operation and are more fully discussed in the Operational Modes section.

## Fs/4 Quadrature Down Convert Processor

The Fs/4 Quadrature Down Convert Processor operates as a Quadrature LO which provides the negative $F_{S} / 4$ spectral shift required to center the upper sideband of a real input signal at DC. This operation is equivalent to multiplying the real sample stream, $x(n)$, by the quadrature components of the complex exponential $e^{-j(\pi / 2) \mathrm{n}}$ as given below:

$$
x(n) e^{-j(\pi n / 2)}=x(n) \cos (\pi n / 2)+j x(n) \sin (-\pi n / 2)
$$

For added flexibility, a spectrally reversed version of the above process may be realized by configuring the Down Convert processor to impart a positive $F_{\mathrm{S}} / 4$ spectral shift on the input signal. This has the effect of centering the lower sideband of the input signal at DC and is achieved by reversing the sign of the sine term in the quadrature mix as shown below:

$$
x(n) e^{j(\pi n / 2)}=x(n) \cos (\pi n / 2)+j x(n) \sin (\pi n / 2)
$$

The direction of the spectral shift imparted by the Down Convert Processor is set by the Upper Sideband/ Lower Sideband control input, USB/LSB\#. When this input is "High", a -F $/ 4$ spectral shift is used to center the input signal's upper sideband at DC. When asserted low, a spectral shift of $\mathrm{F}_{\mathrm{S}} / 4$ is used to center the lower sideband at

TABLE 2. FREQUENCY RESPONSE OF THE 67-TAP HALFBAND FILTER NORMALIZED TO THE SAMPLE RATE

| FREQUENCY (NORMALIZED) | MAGNITUDE <br> (dB) | FREQUENCY (NORMALIZED) | MAGNITUDE (dB) | FREQUENCY (NORMALIZED) | MAGNITUDE <br> (dB) | FREQUENCY (NORMALIZED) | MAGNITUDE <br> (dB) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0.000000 | -0.000256 | 0.125000 | -0.000278 | 0.250000 | -6.020594 | 0.375000 | -90.469534 |
| 0.003906 | -0.000143 | 0.128906 | -0.000098 | 0.253906 | -7.989334 | 0.378906 | -91.528735 |
| 0.007812 | -0.000071 | 0.132812 | 0.000001 | 0.257812 | -10.364986 | 0.382812 | -98.960202 |
| 0.011719 | -0.000013 | 0.136719 | 0.000077 | 0.261719 | -13.194719 | 0.386719 | -105.235066 |
| 0.015625 | -0.000004 | 0.140625 | 0.000166 | 0.265625 | -16.533196 | 0.390625 | -97.073218 |
| 0.019531 | -0.000001 | 0.144531 | 0.000106 | 0.269531 | -20.447622 | 0.394531 | -101.790858 |
| 0.023438 | 0.000032 | 0.148438 | 0.000015 | 0.273438 | -25.024382 | 0.398438 | -103.660592 |
| 0.027344 | -0.000000 | 0.152344 | -0.000022 | 0.277344 | -30.379687 | 0.402344 | -96.903272 |
| 0.031250 | -0.000026 | 0.156250 | -0.000048 | 0.281250 | -36.679477 | 0.406250 | -97.160860 |
| 0.035156 | 0.000002 | 0.160156 | -0.000074 | 0.285156 | -44.169450 | 0.410156 | -106.804655 |
| 0.039062 | 0.000036 | 0.164062 | -0.000022 | 0.289062 | -53.259353 | 0.414062 | -96.213761 |
| 0.042969 | 0.000050 | 0.167969 | 0.000005 | 0.292969 | -64.619008 | 0.417969 | -91.368358 |
| 0.046875 | 0.000021 | 0.171875 | 0.000009 | 0.296875 | -79.291213 | 0.421875 | -91.202963 |
| 0.050781 | 0.000008 | 0.175781 | 0.000041 | 0.300781 | -90.247748 | 0.425781 | -96.903271 |
| 0.054688 | -0.000012 | 0.179688 | 0.000095 | 0.304688 | -91.540418 | 0.429688 | -103.058722 |
| 0.058594 | -0.000140 | 0.183594 | 0.000090 | 0.308594 | -96.987389 | 0.433594 | -92.156508 |
| 0.062500 | -0.000226 | 0.187500 | -0.000012 | 0.312500 | -97.990997 | 0.437500 | -90.247741 |
| 0.066406 | -0.000138 | 0.191406 | -0.000037 | 0.316406 | -94.450644 | 0.441406 | -91.623161 |
| 0.070312 | 0.000010 | 0.195312 | -0.000145 | 0.320312 | -94.268681 | 0.445312 | -98.760392 |
| 0.074219 | 0.000036 | 0.199219 | -0.000208 | 0.324219 | -97.250387 | 0.449219 | -103.883238 |
| 0.078125 | 0.000179 | 0.203125 | -0.000927 | 0.328125 | -103.660592 | 0.453125 | -96.861830 |
| 0.082031 | 0.000190 | 0.207031 | -0.005089 | 0.332031 | -105.940671 | 0.457031 | -96.987388 |
| 0.085938 | 0.000064 | 0.210938 | -0.018871 | 0.335938 | -98.212931 | 0.460938 | -100.046559 |
| 0.089844 | 0.000011 | 0.214844 | -0.053894 | 0.339844 | -94.313447 | 0.464844 | -106.804655 |
| 0.093750 | -0.000064 | 0.218750 | -0.128250 | 0.343750 | -95.354251 | 0.468750 | -104.119091 |
| 0.097656 | -0.000018 | 0.222656 | -0.266964 | 0.347656 | -98.447393 | 0.472656 | -105.235066 |
| 0.101562 | -0.000000 | 0.226562 | -0.501238 | 0.351562 | -103.249457 | 0.476562 | -104.637666 |
| 0.105469 | 0.000020 | 0.230469 | -0.866791 | 0.355469 | -93.387604 | 0.480469 | -105.940673 |
| 0.109375 | 0.000053 | 0.234375 | -1.401949 | 0.359375 | -91.390894 | 0.484375 | -107.323099 |
| 0.113281 | 0.000012 | 0.238281 | -2.145948 | 0.363281 | -94.404415 | 0.488281 | -102.375213 |
| 0.117188 | -0.000022 | 0.242188 | -3.137997 | 0.367188 | -103.883234 | 0.492188 | -94.009640 |
| 0.121094 | -0.000149 | 0.246094 | -4.416657 | 0.371094 | -93.245384 | 0.496094 | -91.312516 |

DC. The SYNC\# control input may be used to synchronize the incoming data stream with the zero degree phase of the complex exponential as described in the Operational Modes section.

The real and imaginary sample streams generated by the down convert operation are passed to the Halfband Filter block on the upper and lower processing legs respectively.

The Down Convert Processor is only active in Down Convert and Decimate Mode, MODE1-0 = 10. In the other modes, the data on the upper and lower processing legs pass unaltered.

## 67-Tap Halfband Filter Processor

The processing required to implement the 67-Tap Halfband filter is distributed across two polyphase branches comprised of even and odd tap filters as shown in Figure 1. The Even Tap Filter performs a filtering operation using the even indexed coefficients (even phase) of the halfband filter. The Odd Tap Filter uses the odd indexed coefficients (odd phase) of the halfband filter. Note: the odd tap filter's processing reduces to a delay and scale operation since the center tap is the only non-zero odd tap for a halfband filter. Together the polyphase filters perform the sum of-products required to implement the 67 tap halfband filter in an architecture capable of supporting a variety of operational modes. The frequency response of the halfband filter is given graphically in Figure 2 and in tabular form in Table 2.

The polyphase implementation of the halfband filter provides the flexibility to realize a variety of filter configurations. In Decimate by Two Mode, the outputs of the each polyphase branch are summed to yield the filter output. In Interpolate by Two mode, the polyphase filters produce independent outputs which are multiplexed into a single sample stream at the interpolated data rate. In the Up Convert and Down Convert Modes, the polyphase branches filter the real and imaginary components of a complex sample stream with the equivalent of identical 67-Tap Halfband Filters. For these modes, the real component is processed by the Even Tap filter and the imaginary component is processed by the Odd Tap filter. The Operational Modes Section provides further details regarding the data flow and operation of the Filter Processor for the various modes.


FIGURE 2. FREQUENCY RESPONSE OF 67 - TAP HALFBAND FILTER

## Fs/4 Quadrature Up Convert Processor

The $F_{S} / 4$ Quadrature Up Convert Processor provides the $F_{\mathrm{S}} / 4$ spectral shift used to construct a real signal from a complex sample stream. The operation performed is equivalent to multiplying a quadrature data stream, $i(n)+j q(n)$, by samples of a complex exponential, $e^{-j(\pi / 2) n}$, and outputting the real part of that mathematical operation as given below:

$$
\text { Real } \begin{aligned}
\{ & \left.(i(n)+j q(n)) e^{j(\pi n / 2)}\right\} \\
= & \text { Real }\{[i(n) \cos (\pi n / 2)-q(n) \sin (\pi n / 2)] \\
& +j[i(n) \sin (\pi n / 2)+q(n) \cos (\pi n / 2)]\} \\
= & i(n) \cos (\pi n / 2)-q(n) \sin (\pi n / 2) \\
= & i(n) \cos (\pi n / 2)+q(n) \sin (-\pi n / 2)
\end{aligned}
$$

In the above operation, a positive $F_{S} / 4$ spectral shift is imparted on the quadrature input which causes the upper sideband of the resulting real output to be defined by the spectral content of the input signal. For added flexibility, the Up Convert processor may be configured to impart a negative $\mathrm{F}_{\mathrm{S}} / 4$ shift on the quadrature input which generates a real output whose lower sideband is defined the spectrum of the quadrature input. The state of the USB/LSB\# control input determines the direction of the spectral shift. If this input is set "High", a positive $F_{S} / 4$ shift is introduced by the Up Convert Processor. If USB/LSB\# is asserted "Low", a negative $F_{S} / 4$ spectral shift is introduced.

The Up Convert Processor implements the up convert operation by multiplying the in-phase and quadrature samples on the upper and lower processing legs by the nonzero sine and cosine terms in the above expression. The resulting data is then multiplexed together in the Output Flow Controller to yield the real output sample stream. The SYNC\# control input may be used to align the zero degree phase of the Up Convert LO with a particular input sample as described in the Operational Modes Section.

The Up Convert Processor also scales the data streams output from the Filter Processor as required by the operational mode. In the modes which employ interpolation, the Up Convert Processor scales the Filter Processor's output by two to compensate for the attenuation of one half caused by the interpolation process. In down convert and decimate mode, the filter processor output is also scaled by two to compensate for the attenuation introduced by the down covert process. The scaling operations performed are summarized in Table 3.
TABLE 3. SCALE FACTORS APPLIED BY UP CONVERT

PROCESSOR vS MODE

| MODE | SCALE FACTOR |
| :--- | :---: |
| Decimate by Two (MODE1-0 = 00) | 1.0 |
| Interpolate by Two (MODE1-0 = 01) | 2.0 |
| Down Convert and Decimate (MODE1-0 = 10) | 2.0 |
| Quadrature to Real (MODE1-0 =11) | 2.0 |

## Output Data Flow Controller

The Output Flow Controller routes data to the AOUTO-15 and BOUTO-15 output depending on mode of operation. In decimate by two mode (MODE1-0 = 00), output from the filter processor's polyphase branches are summed and output through AOUTO-15. In Down Convert and Decimate mode (MODE1-0 $=10$ ), real and imaginary data streams produced by the down convert process pass are output directly to AOUTO-15 and BOUTO-15 respectively. In the two modes using interpolation, MODE1-0 $=01$ or 11, with internal multiplexing enabled, INT/EXT\# set high, data sam ples output from the polyphase branches are internally multiplexed into a single stream and output via AOUTO-15. If a mode using interpolation is specified together with external multiplexing, INT/EXT\# set low, the data stream multiplexing is performed off chip and the data on the upper and lower processing legs is output through AOUTO-15 and BOUT015.
The Output Data Flow Controller also sets the binary format and precision of the parts two 16 -bit outputs. The data format is specified as either two's complement (FMT input low) or offset binary (FMT input high). The precision of the output data is set from 8 to 16 -bits via the round control inputs, RND2-0. The RND2-0 inputs round the output data to a precision ranging from 8 to 16-bits as specified in Table 4. Saturation logic is incorporated in the output flow controller to insure that numerical growth associated with a worst case signal input or rounding condition saturates to a 16-bit value.

TABLE 4. OUTPUT ROUNDING CONTROL

| RND <br> 2-0 | ROUND FUNCTION |
| :---: | :--- |
| 000 | Round output to 8-bits, AOUT15-8 and BOUT15-8, zero <br> lower bits. |
| 001 | Round output to 9-bits, AOUT15-7 and BOUT15-7, zero <br> lower bits. |
| 010 | Round output to 10-bits, AOUT15-6 and BOUT15-6, zero <br> lower bits. |
| 011 | Round output to 11-bits, AOUT15-5 and BOUT15-5, zero <br> lower bits. |
| 100 | Round output to 12-bits, AOUT15-4 and BOUT15-4, zero <br> lower bits. |
| 101 | Round output to 14-bits, AOUT15-2 and BOUT15-2, zero <br> lower bits. |
| 110 | Round output to 16-bits, AOUT15-0 and BOUT15-0. |
| 111 | Zero all outputs. |

## Operational Modes

## Decimate By 2 Filter Mode (Mode1-0=00)

The concept of operation for Decimate by Two Filter mode is most easily understood by comparing the 7 tap transversal filter implementation to the equivalent polyphase implementation. The transversal implementation is shown in Figure 3.


By inspecting the sum-of-products for the decimated output in Figure 3, it is seen that even indexed input samples are always multiplied by the even filter coefficients and the odd samples are always multiplied by the odd coefficients. This computational partitioning is realized in the polyphase implementation shown in Figure 4.
In the polyphase implementation, the input data is broken into even and odd sample streams which are processed by a set of polyphase filters running at one half of the input data rate. These filters are designated as even or odd tap filters depending upon whether the coefficients were derived from the even or odd indexed coefficients of the original transversal filter. This architecture only produces the outputs which are not discarded by the decimation proces. NOTE: since the only non-zero tap for a halfband filter is the center tap, the Odd Tap Filter reduces to a delay and multiply operation.

The operation of the HSP43216 in Decimate by Two mode is analogous to the polyphase implementation in Figure 4. In this mode, the internal data paths are routed as shown in Figure 5A and Figure 5B. The different data flows depend on whether internal or external multiplexing has been selected using the INT/EXT\# control input. In either case, an input data stream is decomposed into even and odd sample streams which are then routed to the even and odd tap polyphase filters. The output of each polyphase filter is summed and output via AOUTO-15.

$Y(0)=X_{0}(C 0)+X_{1}(C 1)+X_{2}(C 2)+X_{3}(C 3)+X 4(C 4)+X 5(C 5)+X 6(C 6)$
$Y(1)=X 2(C 0)+X 3(C 1)+X 4(C 2)+X 5(C 3)+X 6(C 4)+X 7(C 5)+X 8(C 6)$
$\bullet$
FIGURE 4. POLYPHASEIMPLEMENTATION OF DECIMATE BY 2 HALFBAND FILTER


FIGURE 5B. DATA FLOW DIAGRAM FOR DECIMATE BY 2 FILTER MODE (INT/EXT\# = 0)

If internal multiplexing is selected (INT/EXT\# = 1), the input data stream is decomposed into even and odd samples internally by the processing elements operating at one half of the input CLK (see elements marked by "**" in Figure 5A). In this mode, the Data Flow Controller routes data samples input through AINO-15 to upper and lower processing legs with a one sample relative delay. Since a new data sample is clocked into either of the processing legs at CLK/2, each leg processes a data stream comprised of every other input sample, and the one sample relative delay of each leg's input forces the even samples to be clocked into one leg while the odd samples are clocked into the other. The user may choose which sample gets routed to the upper (even) processing leg by asserting SYNC\#. Specifically, a sample input on the CLK following the assertion of SYNC\# will be routed to the upper processing leg as shown in Figure 6. With internal multiplexing, the minimum pipeline delay on the upper processing leg is 14 CLK's and the pipeline delay on the bottom leg is 47 CLK's. The filtered and decimated data stream is held on AOUTO-15 for 2 CLK's.

If external multiplexing is selected (INT/EXT\# = 0), a demultiplex function is required off chip to break the input data into even and odd sample streams for input through AIN0-15 and BINO-15. In this mode, the Data Flow Controller routes the even and odd sample streams directly to the following processing elements which are all running at the input CLK rate. This allows the device to perform decimate by two filtering on signals sampled at up to twice the maximum CLK rate of the device ( 104 MSPS). With external multiplexing, the minimum pipeline delay through the upper processing leg is 9 CLK's and the pipeline delay through the lower processing leg is 26 CLK's as shown in Figure 5B. In
this mode, SYNC\# has no effect on part operation. NOTE: for proper operation, the samples demultiplexed to the AINO15 input must precede those input to the BINO-15 input in sample order. For example, given a data sequence $\times 0, \times 1$, $x 2$ and $x 3$, the demultiplex function would route $\times 0$ and $\times 2$ to AINO-15 and $x 1$ and $x 3$ to BINO-15.


INPUTS DEsignated as even are processed on the upper LEG, inputs designated as odd are processed on the LOWER LEG.
FIGURE 6. DATA SYNCHRONIZATION WITH PROCESSING LEGS (INT/EXT\# = 1)

## Interpolate By 2 Filter Mode (Mode1-0 = 01)

As with the Decimate by Two mode the concept of operation for the Interpolate by Two Filter mode is more easily understood by comparing a 7 tap transversal filter implementation to the equivalent polyphase implementation. The transversal implementation is shown in Figure 7.

By inspecting filter outputs in Figure 7, it is seen that the even indexed outputs are the result of the sum-of-products for the odd coefficients, and the odd indexed outputs are theresult of the sum-of-products for the even coefficients. This computational partitioning is evident in the polyphase implementation shown in Figure 8.

$Y(0)=0(C 0)+X 0(C 1)+0(C 2)+X_{1}(C 3)+0(C 4)+X_{2}(C 5)+0(C 6)$
$Y(1)=X 0(C 0)+0(C 1)+X 1(C 2)+0(C 3)+X 2(C 4)+0(C 5)+X 3(C 6)$
$Y(2)=0(C 0)+X 1(C 1)+0(C 2)+X 2(C 3)+0(C 4)+X 3(C 5)+0(C 6)$
$Y(3)=X 1(C 0)+0(C 1)+X 2(C 2)+0(C 3)+X 3(C 4)+0(C 5)+X_{4}(C 6)$ :
FIGURE 7. TRANSVERSAL IMPLEMENTATION OF INTERPOLATE BY TWO HALFBAND FILTER.


FIGURE 8. POLYPHASE IMPLEMENTATION OF INTERPOLATE BY TWO HALFBAND FILTER

In the polyphase implementation, the input data stream feeds even and odd tap filters running at the input sample rate. The interpolated sample stream is derived by multiplexing the output of each polyphase branch into a single data stream at twice the input sample rate. As in the Decimate by Two example, the even or odd tap filters are comprised of the even or odd indexed coefficients from the original transversal filter.

The operation of the HSP43216 in Interpolate by Two mode is analogous to the polyphase example above. In this mode the internal data flow is routed as shown in Figure 9A and Figure 9B. The different data flows depend on the selection of internal or external multiplexing via INT/EXT\#. In this mode, data input through AINO-15 is fed to the even and odd polyphase branches of the filter processor. The output of each branch is multiplexed together to generate the output data stream at the interpolated rate. NOTE: the output of each polyphase branch is scaled by two to compensate for the attenuation of one half caused by interpolation.

If internal multiplexing is selected (INT/EXT\# =1), the data stream input through AINO-15 is fed to both the upper and lower processing legs as shown in Figure 9A. The output of each processing leg is then multiplexed together to produce the interpolated sample stream at twice the input sample rate. In this mode the device is clocked at the interpolated data rate to support the multiplexing of each processing leg's output into a single data stream. The upper and lower processing legs each run at the input data rate of CLK/2 as indicated by the "**" marking the various registers and processing elements in Figure 9A. In this mode, data samples are clocked into the part on every other rising edge of CLK. The SYNC\# signal is used to specify which set of CLK


FIGURE 9A. DATA FLOW DIAGRAM FOR INTERPOLATE BY 2 FILTER MODE (INT/EXT* = 1)


FIGURE 9B. DATA FLOW DIAGRAM FOR INTERPOLATE BY 2 FILTER MODE (INT/EXT\# = 0)
cycles are used to register data at the part's input. Specifically, every other rising edge of CLK starting one CLK after the assertion of SYNC\# will be used to clock data into the part. With internal multiplexing the minimum pipeline delay through the upper processing leg is 15 CLK's and the pipeline delay through the lower processing leg is 48 CLK's.

If external multiplexing is selected (INT/EXT\# = 0), the upper and lower processing legs are output through AOUTO-15 and BOUT0-15 for multiplexing into a single data stream off chip. This allows the processing legs to run at the maximum clock rate which coincides with an interpolated output data rate of 104 MSPS. NOTE: the samples output on BOUTO-15 precede those on AOUTO-15 in sample order. This requires a multiplexing scenario in which BOUTO-15 is selected before AOUTO-15. With external multiplexing, the minimum pipeline delay through the upper processing leg is 9 CLK's and the pipeline delay through the lower processing leg is 26 CLK's as shown in Figure 9B. In this mode SYNC\# has no effect on part operation.

## Down Convert and Decimate Mode (MODE1-0 = 10)

In Down Convert and Decimate Mode a real input signal is spectrally shifted -F/4 which centers the upper sideband at DC. This operation produces real and imaginary components which are each filtered and decimated by identical 67-tap halfband filters. For added flexibility, a positive $F_{S} / 4$ spectral shift may be selected which centers the lower sideband at DC. The direction of the spectral shift is selected via USB/LSB\# as described in the Quadrature Down Convert section. A spectral representation of the down convert and decimate operation is shown in Figure 10 (USB/ LSB\#=1). NOTE: each of the complex terms output by the Filter Processor are scaled by two to compensate for the attenuation of one half introduced by the down conversion process.
The Down Convert and Decimate mode is most easily understood by first considering the transversal implementation using a 7 tap filter as shown in Figure 11.
By examining the combination of down conversion, filtering and decimation, it is seen that the real outputs are only dependent on the sum-of-products for the even indexed samples and filter coefficients, and the imaginary outputs are only a function of the sum-of-products for the odd indexed samples and filter coefficients. This computational partitioning allows the quadrature filters required after down conversion to be realized using the same poly-phase processing elementsused in the previous two modes.
A functional block diagram of the polyphase implementation is shown in Figure 12. In this implementation, the input data stream is broken into even and odd sample streams and processed independently by the even and odd tap filters. By decomposing the sample stream into even and odd samples, the zero mix terms produced by the down convert LO drop out of the data streams, and the output of each of the filters represent the decimated data streams for both the real and imaginary outputs.

down converted signal


FILTERED SIGNAL


DECIMATED OUTPUT SIGNAL SPECTRUM

$\mathbf{F}_{\mathbf{S}}=$ INPUT SAMPLE RATE
$F_{S}^{\prime}=$ DECIMATED SAMPLE RATE,F $\mathbf{F}_{\mathbf{S}} / 2$
FIGURE 10. DOWN CONVERT AND DECIMATE OPERATION


FIGURE 12. DOWN CONVERT AND DECIMATE FUNCTION USING POLYPHASE FILTERS

The HSP43216's implementation of Down Convert and Decimate mode is analogous to the polyphase solution shown in Figure 12. The part's data flow diagram for this mode is shown in Figure 13A and Figure 13B. As seen in the figures, the input sample data is broken into even and odd sample streams which feed the upper and lower processing legs as described in the Decimate By 2 Mode section. The data on each processing leg is then modulated with the non zero quadrature components of the complex exponent (see Quadrature Down Convert Section). Following this operation, the upper leg becomes the processing chain for
the real (in-phase) component of the quadrature down conversion and the lower leg processes the complex (Quadrature) component of the down conversion. The filter processing block implements the equivalent of a decimate by two Halfband filter on each of the quadrature legs.

If internal multiplexing is specified (INT/EXT\# = 1), the upper and lower processing legs are fed with even and odd sample streams which are derived from data input through AINO-15. The input sample stream may be synchronized with the zero degree phase term of the down converter LO by using the SYNC\# control input. For example, an input data sample will be fed into the real (upper) processing leg and mixed with the zero degree cosine term of the quadrature LO if it is input on the 4th CLK following the assertion of SYNC\# as shown in Figure 14. The pipeline delay through the real processing leg (upper leg) is 14 CLK's and the delay through the imaginary processing leg (lower leg) is 47 CLK's. The complex samples output through AOUT0-15 and BOUT0-15 are present for 2 CLK's since the quadrature streams have been decimated by two in the filter processor.


THE SAMPLE DESIGNATED BY THE $0^{\circ}$ AND $180^{\circ}$ LABELS ARE
MIXED WITH THE RESPECTIVE COSINE TERMS ON THE UPPER PROCESSING LEG, AND THE OTHER SAMPLES, THOSE LABELED BY $90^{\circ}$ AND $270^{\circ}$, ARE MIXED WITH THE RESPECTIVE SINE TERMS ON THE LOWER LEG.
FIGURE 14. DATA SYNCHRONIZATION TO $0^{\circ}$ PHASE OF QUADRATURE LO


FIGURE 13A. DATA FLOW DIAGRAM FOR DOWN CONVERT AND DECIMATE MODE (INT/EXT* = 1 )


FIGURE 13B. DATA FLOW DIAGRAM FOR DOWN CONVERT AND DECIMATE MODE (INT/EXT\# $=0$ )

If external multiplexing is selected (INT/EXT\# $=0$ ), a demultiplex function is required off chip to break the input data stream into even and odd samples for input through AINO-15 and BINO-15. In this mode, the real and imaginary processing legs run at the input clock rate which allows the device to perform the down convert and decimate function on real signals sampled at up to twice the maximum speed grade of the device ( 104 MSPS). With external multiplexing, the minimum pipeline delay through the upper processing leg is 9 CLK's and the pipeline delay through the lower processing leg is 26 CLK's as shown in Figure 13B. To synchronize the even samples input through AINO-15 with the zero degree cosine term of the quadrature LO, SYNC\# should be asserted on the same clock that the target sample is present at the input of the part as shown in Figure 15. NOTE: for proper operation, the samples demultiplexed to the AINO-15 input must precede those input to the BINO-15 input in sample order. For example, given a data sequence $\times 0, \times 1, \times 2$, and $\times 3$, the demultiplex function would route $\times 0$ and $x 2$ to AINO-15 and $x 1$ and $x 3$ to BINO-15.


The $0^{\circ}$ and $180^{\circ}$ Labels indicate the phase alignment of THE SAMPLES INPUT THROUGH AINO-15 WITH THE COSINE TERM OF THE QUADRATURE DOWN CONVERT LO.

FIGURE 15. DATA SYNCHRONIZATION WITH PHASE OF DOWN CONVERT LO

## Quadrature to Real Conversion Mode (MODE1-0 = 10)

The Quadrature to Real Conversion mode is used to construct a real output from a quadrature input. To accomplish this, the Halfband Filter Processor interpolates the quadrature components of the complex input signal by a factor of two. Next, the Quadrature Up-Convert Processor spectrally shifts the signal by $F_{S} / 4$ and derives the real output as described in the $F_{S} / 4$ Quadrature Up-Convert Processor Section. The direction of the spectral shift is controlled via the USB/LSB\# input and is used to designate the frequency content of the complex input as either the upper or lower sideband of the resulting real output signal. A spectral representation of quadrature to real conversion is shown in Figure 16 for USB/LSB\# = 1. NOTE: the F S $^{\prime} / 4$ UpConvert Processor uses quadrature mix factors scaled by two to compensate for the attenuation introduced by the interpolation process.

The Quadrature to Real Conversion mode is most easily understood by first considering an implementation using a 7 tap transversal filter as shown in Figure 17. By examining the combination of interpolation, filtering, and up conversion it is seen that a particular output is only dependent on the sum-of-products for the even indexed samples and coefficientsor the sum-of-products for the odd indexed samples and coefficients. This computational partitioning allows the dual interpolation filters required in this $m$ ode to be realized using the same poly-phase filter structure used in the other modes.

A functional block diagram of the polyphase implementation for Quadrature to Real Conversion mode is shown in Figure 18. In this implementation, the real and imaginary components of a complex input stream drive the even and odd tap filters. The output of each filter is then modulated by the non-zero mix factors and multiplexed into a single real output stream.

$F_{S}=$ INPUT SAMPLE RATE
$\mathbf{F}_{\mathbf{S}}=$ INTERPOLATED SAMPLE RATE, $^{2 F_{S}}$
FIGURE 16. QUADRATURE TO REAL CONVERSION
As in the other modes, the operation of the HSP43216 in Quadrature to real Conversion mode is analogous to that of the polyphase solution described above. The data flow diagrams for this particular mode are shown in Figures 19A and 19B.

$Y(0)=0(0(C 0)+\mathrm{RO}(\mathrm{C} 1)+0(\mathrm{C} 2)+\mathrm{R} 1(\mathrm{C} 3)+0(\mathrm{C} 4)+\mathrm{R} 2(\mathrm{C} 5)+0(\mathrm{C} 6))+$ $-1(0(\mathrm{CO})+10(\mathrm{C} 1)+0(\mathrm{C} 2)+11(\mathrm{C} 3)+0(\mathrm{C} 4)+12(\mathrm{C} 5)+0(\mathrm{C} 6))$
$\mathrm{Y}(1)=1(\mathrm{RO}(\mathrm{C0})+0(\mathrm{C} 1)+\mathrm{R1}(\mathrm{C} 2)+0(\mathrm{C} 3)+\mathrm{R} 2(\mathrm{C} 4)+0(\mathrm{C} 5)+\mathrm{R} 3(\mathrm{C} 6))+$ $0(10(\mathrm{C} 0)+0(\mathrm{C} 1)+11(\mathrm{C} 2)+0(\mathrm{C} 3)+12(\mathrm{C} 4)+0(\mathrm{C} 5)+13(\mathrm{C} 6))$
$Y(2)=0(0(C)=R 1(C 1)+0(C 2)+R 2(C 3)+0(C 4)+R 3(C 5)+0(C 6))+$ $1(0(\mathrm{C} 0)+11(\mathrm{C} 1)+0(\mathrm{C} 2)+12(\mathrm{C} 3)+0(\mathrm{C} 4)+13(\mathrm{C} 5)+0(\mathrm{C} 6))$
$Y(3)=-1\left(R_{1}(C 0)+0(C 1)+R 2(C 2)+0(C 3)+R 3(C 4)+0(C 5)+R 4(C 6)\right)+$ $0(11(\mathrm{C} 0)+0(\mathrm{C} 1)+12(\mathrm{C} 2)+0(\mathrm{C} 3)+13(\mathrm{C} 4)+0(\mathrm{C} 5)+14(\mathrm{C} 6))$ $\vdots$

FIGURE 17. QUADRATURE TO REAL CONVERTER USING TRANSVERSAL FILTERS


$$
\begin{aligned}
& Y(0)=-1(10(C 1)+11(C 3))+12(C 5)) \\
& Y(1)=1(R 0(C 0)+R 1(C 2)+R 2(C 4))+R 3(C 6)) \\
& Y(2)=1(11(C 1)+12(C 3)+13(C 5)) \\
& Y(3)=-1(R 1(C 0)+R 2(C 2)+R 3(C 4)+R 4(C 6))
\end{aligned}
$$

FIGURE 18. POLYPHASE IMPLEMENTATION OF QUADRATURE TO REAL CONVERTER
If Internal Multiplexing is specified (INT/EXT\# = 1), the real and imaginary components of the quadrature input are fed through AINO-15 and BINO-15 and processed on the upper and lower legs respectively (see Figure 19A). Each component of the complex input is interpolated, mixed with the non-zero sine and cosine terms of the quadrature LO, and multiplexed together into a real output sample stream through AOUT0-15. Prior to the output multiplexer, the upper and lower processing legs each run at the input data rate of CLK/2 as indicated by the "**" marking the various registers and processing elements in Figure 19A. The complex input sample stream may be synchronized with the zero degree phase of the up converters quadrature LO by asserting the SYNC\# control input one cycle prior to the targeted data
sample as shown in Figure 20. This ensures that the real sample input on the upper processing leg will be mixed with the zero degree cosine term. The minimum pipeline delay through the real processing leg (upper leg) is 15 CLK's and the delay through the imaginary processing leg (lower leg) is 48 CLK's.


THE $0^{\circ}$ LABEL INDICATES THE SAMPLE WHICH WILL BE MIXED WITH THE $0^{\circ}$ COSINE TERM OF THE QUADRATURE UP-CONVERT LO.

FIGURE 20. DATA SYNCHRONIZATION WITH PROCESSING LEGS (INT/EXTH = 1)
If external multiplexing is selected ( $\mathrm{INT} / E X T \#=0$ ), output from the upper and lower processing legs exit through AOUTO-15 and BOUTO-15 for multiplexing into a single data stream off chip (see Figure 19B). This allows the processing legs to run at the maximum CLK rate which coincides with an interpolated output data rate of up to 104MSPS. NOTE: the output on BOUTO-15 precedes that on AOUTO-15 in sample order. This requires a multiplexing scenario which selects BOUTO-15 then AOUTO-15 on each CLK of the HSP43216. With external multiplexing, the minimum pipeline delay through the upper processing leg is 9 CLK's and the pipeline delay through the lower processing leg is 26 CLK's as shown in Figure 19B. The SYNC\# control input is used as described in the preceding paragraph.


FIGURE 19A. DATA FLOW DIAGRAM FOR QUADRATURE TO REAL CONVERSION MODE (INT/EXT\# = 1)


FIGURE 19B. DATA FLOW DIAGRAM FOR QUADRATURE TO REAL CONVERSION MODE (INT/EXT\# $=0$ )

## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| :---: | :---: | :---: |
| PGA Package | $37.2^{\circ} \mathrm{C} / \mathrm{N}$ | $6^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC Package | $23.0^{\circ} \mathrm{C}$ W | $9^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$ |  |  |
| PGA Package |  | 2.8W |
| PLCC Package |  | 3.5W |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

Operating Conditions
Operating Voltage Range
+4.75 V to +5.25 V Operating Temperature Range
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
DC Electrical Specifications $\quad\left(V_{C C}=5.0 V_{ \pm 5 \%}, T_{A}=0^{\circ}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Current | Iccop | - | 468 | mA | $\begin{aligned} & \mathrm{V}_{\text {cC }}=\text { Max, CLK Frequency } 52 \mathrm{MHz} \text { INT' } \\ & \text { EXT\# = ' } 4 \text { ', } \\ & \text { Notes } 1,3 \end{aligned}$ |
|  |  | - | 572 | mA | $\mathrm{V}_{\text {CC }}=$ Max, CLK Frequency 52 MHz INT/ <br> EXT\# = '0', <br> Notes 2, 3 |
| Standby Power Supply Current | $l_{\text {ccse }}$ | - | 500 | $\mu \mathrm{A}$ | $V_{C C}=$ Max, Outputs Not Loaded |
| input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| Output Leakage Current | 10 | -10 | 10 | $\checkmark$ | $\mathrm{V}_{C C}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{C C}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{HCC}}$ | 3.0 | - | v | $\mathrm{V}_{\mathrm{cc}}=\mathrm{Max}$ |
| Clock Input Low | $V_{\text {ILC }}$ | - | 0.8 | $\checkmark$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{Cc}}=\mathrm{Max}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical One Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | $\checkmark$ | $\mathrm{IOH}=-3 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical Zero Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{CLC}^{\prime}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 12 | pF | CLK Frequency 1 MHz , |
| Output Capacitance | Cout | - | 12 | pF |  |

NOTES:

1. Power supply current is proportional to frequency. Typical rating is $9 \mathrm{~mA} / \mathrm{MHz}$ when Internal Multiplexing is selected, INT/EXT\# $=1$.
2. Power supply current is proportional to frequency. Typical rating is $11 \mathrm{~mA} / \mathrm{MHz}$ when External Multiplexing is selected, INT/EXT\# = 0 .
3. Output load per test circuit and $C_{L}=40 \mathrm{pF}$.
4. Not tested, but characterized at initial design and at major process/design changes.
5. Maximum junction temperature must be considered when operating part at high clock frequencies.

## AC Electrical Specifications (Note 1)

| PARAMETER | SYMBOL | 52 MHz |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ | 19 | - | ns | - |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 7 | - | ns | - |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 7 | - | ns | - |
| Setup Time AINO-15, BiNO-15 to CLK | $\mathrm{T}_{\mathrm{DS}}$ | 7 | - | ns | - |
| Hold Time AINO-15, BINO-15from CLK | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | ns | - |
| MODEO-1, RNDO-2, INT/EXT\#,SYNC\#,USB/LSB\# Setup Time to CLK | $\mathrm{T}_{\text {RS }}$ | 7 | - | ns | - |
| MODE0-1, RND0-2, INT/EXT\#,SYNC\#,USB/LSB\# Hold Time to CLK | $\mathrm{T}_{\mathrm{RH}}$ | 0 | - | ns | - |
| CLK to AOUTO-15, BOUTO-15 Delay | $\mathrm{T}_{\mathrm{DO}}$ | - | 9 | ns |  |
| Output Enable Time | $\mathrm{T}_{\text {OE }}$ | - | 9 | ns | - |
| Output Disable Time | TOD | - | 9 | ns | Note 2 |
| Output rise, fall time | $\mathrm{T}_{\text {RF }}$ | - | 3 | ns | Note 2 |

NOTES:

1. AC tests performed with $C_{L}=40 \mathrm{pF}, \mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$, and $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$. Input reference level for $C L K$ is 2.0 V , all other inputs 1.5 V . Test $\mathrm{V}_{\mathrm{H}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{HC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.

AC Test Load Circuit


SWITCH S1 OPEN FOR Iccse AND Iccop
Waveforms


OUTPUT RISE AND FALL TMES


Decimating Digital Filter

## Features

- Single Chip Narrow Band Filter with up to 96dB Attenuation
- DC to 33MHz Clock Rate
- 16-Bit 2's Complement Input
- 20-Bit Coefficients in FIR
- 24-Bit Extended Precision Output
- Programmable Decimation up to a Maximum of 16,384
- Standard 16-Bit Microprocessor Interface
- Filter Design Software Available DECI॰MATE ${ }^{\text {m }}$


## Applications

- Very Narrow Band Filters
- Zoom Spectral Analysis
- Channelized Receivers
- Large Sample Rate Converter


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :--- | :--- |
| HSP43220VC-15 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43220VC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43220VC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43220JC-15 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43220JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43220JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43220GC-15 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP43220GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP43220GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP43220TM-15 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead TAB |
| HSP43220TM-25 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead TAB |

## Description

The HSP43220 Decimating Digital Filter is a linear phase low pass decimation filter which is optimized for filtering narrow band signals in a broad spectrum of a signal processing applications. The HSP43220 offers a single chip solution to signal processing application which have historically required several boards of IC's. This reduction in component count results in faster development times as well as reduction of hardware costs.

The HSP43220 is implemented as a two stage filter structure. As seen in the block diagram, the first stage is a high order decimation filter (HDF) which utilizes an efficient decimation (sample rate reduction) technique to obtain decimation up to 1024 through a coarse low-pass filtering process. The HDF provides up to 96 dB aliasing rejection in the signal pass band. The second stage consists of a finite impulse response (FIR) decimation filter structured as a transversal FIR filter with up to 512 symmetric taps which can implement filters with sharp transition regions. The FIR can perform further decimation by up to 16 if required while preserving the 96 dB aliasing attenuation obtained by the HDF. The combined total decimation capability is 16,384 .

The HSP43220 accepts 16-bit parallel data in 2's complement format at sampling rates up to 33MSPS. It provides a 16 -bit microprocessor compatible interface to simplify the task of programming and three-state outputs to allow the connection of several IC's to a common bus. The HSP43220 also provides the capability to bypass either the HDF or the FIR for additional flexibility.

The pinout TAB package can be obtained by referring to the Metallization Mask Layout of the HSP43220/883 data sheet.

## Block Diagram



DECl•MATE ${ }^{\text {1M }}$ is a registered trademark of Harris Corporation.
IBM PCNN $, ~ X T^{T M}, ~ A T^{T M}, ~ P S / 2^{\text {M }}$ are registered trademarks of International Business Machines, Inc.

84 PIN GRID ARRAY (PGA)


84 PLASTIC LEADED CHIP CARRIER (PLCC)


## Pinouts (Continued)



## Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} 13,28,42,45, \\ 60,75,78 \\ \hline \end{gathered}$ |  | The +5 V power supply pins. |
| GND | $\begin{gathered} 11,29,43,46, \\ 61,74,77 \\ \hline \end{gathered}$ |  | The device ground. |
| CK_IN | 76 | 1 | Input sample clock. Operations in the HDF are synchronous with the rising edge of this clock signal. The maximum clock frequency is 33 MHz . CK_IN is synchronous with FIR_CK and thus the two clocks may be tied together if required, or CK__IN can be divided down from FIR_CK. CK_IN is a CMOS level signal. |
| FIR_CK | 44 | 1 | Input clock for the FIR filter. This clock must be synchronous with CK_IN. Operations in the FIR are synchronous with the rising edge of this clock signal. The maximum clock frequency is 33 MHz . FIR__CK is a CMOS level signal. |
| DATA_INO-15 | 1-10,79-84 | 1 | Input Data bus. This bus is used to provide the 16-bit input data to the HSP43220. The data must be provided in a synchronous fashion, and is latched on the rising edge of the CK_IN signal. The data bus is in 2's complement fractional format. |
| C._.BUSO-15 | 21-27, 30-38 | 1 | Control Input bus. This input bus is used to load all the filter parameters. The pins WR\#, CS\# and AO, A1 are used to select the destination of the data on the Control bus and write the Control bus data into the appropriate register as selected by AO and A1. |
| $\begin{gathered} \text { DATA_OUT } \\ 0-23 \end{gathered}$ | 48-59, 62-73 | 0 | Output Data bus. This 24-Bit output port is used to provide the filtered result in 2's complement format. The upper 8 bits of the output, DATA__OUT16-23 will provide extension or growth bits depending on the state of OUT_SELH and whether the FIR has been put in bypass mode. Output bits DATA_OUTO-15 will provide bits $2^{0}$ through 2-15 when the FIR is not bypassed and will provide the bits $2^{-16}$ through $2^{-31}$ when the FIR is in bypass mode. |
| DATA_RDY | 47 | 0 | An active high output strobe that is synchronous with FIR_CK that indicates that the result of the just completed FIR cycle is available on the data bus. |
| RESET\# | 16 | 1 | RESET\# is an asynchronous signal which requires that the input clocks CK__IN and FIR_CK are active when RESET\# is asserted. RESET\# disables the clock divider and clears all of the internal data registers in the HDF. The FIR filter data path is not initialized. The control register bits that are cleared are F_BYP, H__STAGES, and H__DRATE. The F__DIS bit is set. In order to guarantee consistent operation of the part, the user must reset the DDF after power up. |
| WR\# | 19 | 1 | Write strobe. WR\# is used for loading the internal registers of the HSP43220. When CS\# and WR\# are asserted, the rising edge of WR\# will latch the C__BUSO-15 data into the register specified by AO and A1. |
| CS\# | 20 | 1 | Chip Select. The Chip Select input enables loading of the internal registers. When CS\# and WR\# are low, the AO and A1 address lines are decoded to determine the destination of the data on C_BUSO-15. The rising edge of WR\# then loads the appropriate register as specified by AO and A1. |
| AO, A1 | 18, 17 | 1 | Control Register Address. These lines are decoded to determine which control register is the destination for the data on C__BUSO-15. Register loading is controlled by the AO and A1, WR\# and CS\# inputs. |
| ASTARTIN\# | 15 | 1 | ASTARTIN\# is an asynchronous signal which is sampled on the rising edge of CK_IN. It is used to put the DDF in operational mode. ASTARTIN\# is internally synchronized to CK_IN and is used to generate STARTOUT\#. |
| STARTOUT\# | 12 | $\bigcirc$ | STARTOUT\# is a pulse generated from the internally synchronized version of ASTARTIN\#. It is provided as an output for use in multi-chip configurations to synchronously start multiple HSP43220's. The width of STARTOUT\# is equal to the period of CK_IN. |
| STARTIN\# | 14 | 1 | STARTIN\# is a synchronous input. A high to low transition of this signal is required to start the part. STARTIN\# is sampled on the rising edge of CK_IN. This synchronous signal can be used to start single or multiple HSP43220's. |
| OUT__SELH | 39 | 1 | Output Select. The OUT__SELH input controls which bits are provided at output pins DATA_OUT16-23. A HIGH on this control line selects bits $2^{8}$ through $2^{1}$ from the accumulator output. A LOW on this control line selects bits $2^{-16}$ through $2^{-23}$ from the accumulator output. Processing is not interrupted by this pin. |
| OUT_ENP\# | 40 | 1 | Output Enable. The OUT_ENP\# input controls the state of the lower 16 bits of the output data bus, DATA__OUTO-15. A LOW on this control line enables the lower 16 bits of the output bus. When OUT_ENP\# is HIGH, the output drivers are in the high impedance state. Processing is not interrupted by this pin. |
| OUT_ENX\# | 41 | 1 | Output Enable. The OUT_ENX\# input controls the state of the upper 8 bits of the output data bus, DATA_OUT16-23. A LOW on this control line enables the upper 8 bits of the output bus. When OUT_ENX\# is HIGH, the output drivers are in the high impedance state. Processing is not interrupted by this pin. |

## The HDF

The first filter section is called the High Order Decimation Filter (HDF) and is optimized to perform decimation by large factors. It implements a low pass filter using only adders and delay elements instead of a large number of multiplier/ accumulators that would be requited using a standard FIR filter.
The HDF is divided into 4 sections: the HDF filter section, the clock divider, the control register logic and the start logic (Figure 1).

## Data Shifter

After being latched into the Input Register the data enters the Data Shifter. The data is positioned at the output of the shifter to prevent errors due to overflow occurring at the output of the HDF. The number of bits to shift is controlled by H__GROWTH.

## Integrator Section

The data from the shifter goes to the Integrator section. This is a cascade of 5 integrator (or accumulator) stages, which implement a low pass filter. Each accumulator is
implemented as an adder followed by a register in the feed forward path. The integrator is clocked by the sample clock, CK_IN as shown in Figure 2. The bit width of each integrator stage goes from 66 bits at the first integrator down to 26 bits at the output of the fifth integrator. Bit truncation is performed at each integrator stage because the data in the integrator stages is being accumulated and thus is growing, therefore the lower bits become insignificant, and can be truncated without losing significant data.
There are three signals that control the integrator section; they are H_STAGES, H__BYP and RESET\#. In Figure 2 these control signals have been decoded and are labelled INT__EN1 - INT__EN5. The order of the filter is loaded via the control bus and is called H__STAGES. H__STAGES is decoded to provide the enables for each integrator stage. When a given integrator stage is selected, the feedback path is enabled and the integrator accumulates the current data sample with the previous sum. The integrator section can be put in bypass mode by the H__BYP bit. When H__BYP or RESET\# is asserted, the feedback paths in all integrator stages are cleared.


HDF FILTER SECTION


FIGURE 1. HIGH ORDER DECIMATION FILTER


FIGURE 2. INTEGRATOR

## Decimation Register

The output of the Integrator section is latched into the Decimation Register by CK_DEC. The output of the Decimation register is cleared when RESET\# is asserted. The HDF decimation rate $=\mathrm{H} \_$DRATE +1 , which is defined as Hdec for convenience.

## Comb Filter Section

The output of the Decimation Register is passed to the Comb Filter Section. The Comb section consists of 5 cascaded Comb filters or differentiators. Each Comb filter section calculates the difference between the current and previous integrator output. Each Comb filter consists of a register which is clocked by CK_DEC, followed by an subtractor, where the subtractor calculates the difference between the input and output of the register. Bit truncations are done at each stage as shown in Figure 3. The first stage bit width is 26 bits and the output of the fifth stage is 19 bits.
There are three signals that control the Comb Filter; $\mathrm{H}_{-}$ STAGES, H_BYP and RESET\#. In Figure 3 these control signals are decoded as COMB_EN1 - COMB__EN5. The order of the Comb filter is controlled by H__STAGES, which is programmed over the control bus. H_BYP is used to put the comb section in bypass mode. RESET\# causes the register output in each Comb stage to be cleared. The $\mathrm{H}_{-}$ BYP and RESET\# control pins, when asserted force the output of all registers to zero so data is passed through the subtractor unaltered. When the H__STAGES control bits enable a given stage the output of the register is subtracted from the input.

It is important to note that the Comb filter section has a speed limitation. The input sampling rate divided by the decimation factor in the HDF (CK_IN/Hdec) should not exceed 4 MHz . Violating this condition causes the output of the filter to be incorrect. When the HDF is put in bypass mode this limitation does not apply. Equation 1.0 describes the relationship between F_TAPS, F__DRATE, H__DRATE, CK_IN and FIR__CK.

## Rounder

The filter accuracy is limited by the 16 bit data input. To maintain the maximum accuracy, the output of the comb is rounded to 16 bits.

The Rounder performs a symmetric round of the 19 bit output of the last Comb stage. Symmetric rounding is done to prevent the synthesis of a OHz spectral component by the rounding process and thus causing a reduction in spurious free dynamic range. Saturation logic is also provided to prevent roll over from the largest positive value to the most negative value after rounding. The output of the last comb filter stage in the HDF section has a 16 bit integer portion with a 3 bit fractional part in 2's complement format.

The rounding algorithm is as follows:

| $\|$POSITIVE NUMBERS Round Up <br> Fractional Portion Greater Than or <br> Equal to 0.5 Truncate <br> Fractional Portion Less Than 0.5 Round Up <br> NEGATIVE NUMBERS  |
| :--- |
| Fractional Portion Less Than or <br> Equal to 0.5 |
| Fractional Portion Greater Than 0.5 |

The output of the rounder is latched into the HDF output register with CK_DEC. CK_DEC is generated by the Clock Divider section. The output of the register is cleared when RESET\# is asserted.

## Clock Divider and Control Logic

The clock divider divides CK_IN by the decimation factor Hdec to produce CK__DEC. CK__DEC clocks the Decimation Register, Comb Filter section, HDF output register. In the FIR filter CK_DEC is used to indicate that a new data sample is available for processing. The clock generator is cleared by RESET\# and is not enabled until the DDF is started by an internal start signal (see Start Logic).

The Control Register Logic enables the updating of the Control registers which contain all of the filter parameter data. When WR\# and CS\# are asserted, the control register addressed by bits $A 0$ and $A 1$ is loaded with the data on the C__BUS.


FIGURE 3. COMB FILTER

## DDF Control Registers

F_Register ( $\mathrm{A} 1=0, A 0=0$ )


Bits T0-T8 are used to specify the number of FIR filter taps. The number entered is one less than the number of taps required. For example, to specify a 511 tap filter F_TAPS would be programmed to 510 . The minimum number of FIR taps $=3$ (F_TAPS=2).

## F_DRATE

Bits DO-D3 are used to specify the amount of FIR decimation. The number entered is one less than the decimation required. For example, to specify decimation of 16, F_DRATE would be programmed to 15 . For no FIR decimation, F_DRATE would be set equal to O. FDRATE +1 is defined as Fdec.

F__ESYM
Bit ESO is used to select the FIR symmetry. F__ESYM is set equal to one to select even symmetry and set equal to zero to select odd symmetry. When F_ESYM is one, data is added in the pre-adder; when it is zero, data is subtracted. Normally set to one.

F_BYP
Bit FBO is used to select FIR bypass mode. FIR bypass mode is selected by setting F__BYP=1. When FIR bypass mode is selected, the FIR is internally set up for a 3 tap even symmetric filter, no decimation ( $F$ __DRATE $=0$ ) and $F$ _OAD is set equal to one to zero one side of the preadder. In FIR bypass mode all FIR filter parameters, except F_CLA, are ignored, including the contents of the FIR coefficient RAM. In FIR bypass mode the output data is brought output on the lower 16 bits of the output bus DATA__OUT 0-15. To disable FIR bypass mode, F_BYP is set equal to zero. When F_BYP is returned to zero, the coefficients must be reloaded.

## F_OAD

Bit FAO is used to select the zero the preadder mode. This mode zeros one of the inputs to the pre-adder. Zero preadder mode is selected by setting F__OAD equal to one. This feature is useful when implementing arbitrary phase filters or can be used to verify the filter coefficients. To disable the Zero Preadder mode F_OAD is set equal to zero.

FIGURE 4.

## DDF Control Registers (Continued)

FC__Register $(A 1=0, A 0=1)$

| F_CF |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C19 | C18 | C17 | C16 | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | C7 | C6 | C5 | C4 |
| X | X | X | X | X | X | X | X | X | X | X | X | C3 | C2 | C1 | Co |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bits C0-C19 represent the coefficient data, where C19 is the MSB. Two writes are required to write each coefficient which is 2's complement fractional format. The first write loads C19 through C4; C3 through CO are loaded on the second write cycle. As the coefficients are written into this register they are formatted into a 20 bit coefficient and written into the Coefficient RAM sequentially starting with address location zero. The coefficients must be loaded sequentially, with the center tap being the last coefficient to be loaded. See coefficient RAM, below.
figure 5.
$H_{\text {__Register }} 1(A 1=1, A O=0)$

| RESERVED |  |  | F_DIS | F__CLA | H__BYP | H__DRATE |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | FDO | FCO | HBO | R9 | R8 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | RO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bits RO-R9 are used to select the amount of decimation in the HDF. The amount of decimation selected is programmed as the required decimation minus one; for instance to select decimation of 1024 H__DRATE is set equal to 1023. HDRATE +1 is defined as Hdec.
H_BYP
Bit HBO is used to select HDF bypass mode. This mode is selected by setting $H_{Z}$ BYP $=1$. When this mode is selected the input data passes through the HDF unfiltered. Internally H_STAGES and H__DRATE are both set to zero and H__GROWTH is set to 50 . H__REGISTER 2 must be reloaded when H _ BYP is returned to 0 . To disable HDF bypass mode $\mathrm{H} \_$BYP $=0$. The relationship between CK_IN and FIR_CK in this and all other modes is defined by equation 1.0 .

## F_CLA

Bit FCO is used to select the clear accumulator mode in the FIR. This mode is enabled by setting $F$ __CLA $=1$ and is disabled by setting $F_{\ldots} C L A=0$. In normal operation this bit should be set equal to zero. This mode zeros the feedback path in the accumulator of the multiplier/accumualator (MAC). It also allows the multiplier output to be clocked off the chip by FIR_CK, thus DATA__RDY has no meaning in this mode. This mode can be used in conjunction with the F__OAD bit to read out the FIR coefficients from the coefficient RAM.
F__DIS
Bit FDO is used to select the FIR disable mode. This feature enables the FIR parameters to be changed. This feature is selected by setting F_DIS=1. This mode terminates the current FIR cycle. While this feature is selected, the HDF contines to process data and write it into the FIR data RAM. When the FIR re-programming is completed, the FIR can be re-enabled either by clearing F_DIS, or by asserting one of the start inputs, which automatically clears F_DDIS.

FIGURE 6

## DDF Control Registers (Continued)

H_Register 2 ( $\mathrm{A} 1=1, A 0=1$ )

Bits NO-N2 are used to select the number of stages or order of the HDF filter. The number that is programmed in is equal to the required number of stages. For a 5 th order filter, H__STAGES would be set equal to 5 .

## H__GROWTH

Bits G0-G5 are used to select the proper amount of growth bits. H__GROWTH is calculated using the following equation:
H__GROWTH $=50-$ CEILING $\{\mathrm{H}$ __STAGES $\times \log (\mathrm{Hdec}) /$ $\log (2)\}$
where the CEILING \{\} means use the next largest integer of the result of the value in brackets and log is the log to the base 10.
The value of H__GROWTH represents the position of the LSB on the output of the data shifter.

FIGURE 7

## Start Logic

The Start Logic generates a start signal that is used internally to synchronously start the DDF. If ASTARTIN\# is asserted (STARTIN\# must be tied high) the Start Logic synchronizes it to CK_IN by double latching the signal and generating the signal STARTOUT\#, which is shown in Figure 8. The STARTOUT\# signal is then used to synchronously start other DDFs in a multi-chip configuration (the STARTOUT\# signal of the first DDF would be tied to the STARTIN\# of the second DDF). The NAND gate shown in Figure 8 then passes this synchronized signal to be used on chip to provide a synchronous start. Once started, the chip requires a RESET\# to halt operation.

When STARTIN\# is asserted (ASTARTIN\# must be tied high) the NAND gate passes STARTIN\# which is used to provide the internal start, ISTART, for the DDF. When RESET\# is asserted the internal start signal is held inactive, thus it is necessary to assert either ASTARTIN\# or STARTIN\# in order to start the DDF. The timing of the first valid DATA__IN with respect to START_IN\# is shown in the Timing Waveforms below.

In using ASTARTIN\# or STARTIN\# a high to low transition must be detected by the rising edge of CK_IN, therefore these signals must have been high for more than one CK_IN cycle and then taken low.
RESET\#


## The FIR Section

The second filter in the top level block diagram is a Finite Impulse Response (FIR) filter which performs the final shaping of the signal spectrum and suppresses the aliasing components in the transition band of the HDF. This enables the DDF to implement filters with narrow pass bands and sharp transition bands.

The FIR is implemented in a transversal structure using a single multiplier/accumulator (MAC) and RAM for storage of the data and filter coefficients as shown in Figure 9. The FIR can implement up to 512 symmetric taps and decimation up to 16.

The FIR is divided into 2 sections: the FIR filter section and the FIR control logic.

## Coefficient RAM

The Coefficient RAM stores the coefficients for the current FIR filter being implemented. The coefficients are loaded into the Coefficient RAM over the control bus (C_BUS). The coefficients are written into the Coefficient RAM sequentially, starting at location zero. It is only necessary to write one half of the coefficients when symmetric filters are being implemented, where the last coefficient to be written in is the center tap.

The coefficients are loaded into address 01 in two writes. The first write loads the upper 16 bits of the 20 bit coefficient, C4 through C19. The second write loads the lower 4 bits of the coefficient, C0 through C3, where C19 is the MSB. The two 16 bit writes are then formatted into the 20 bit coefficient that is then loaded into the Coefficient RAM starting at RAM address location zero, where the coefficient at this location is the outer tap (or the first coefficient value).

To reload coefficients, the Coefficient RAM Address pointer must be reset to location zero so that the coefficients will be loaded in the order the FIR filter expects. There are two methods that can be used to reset the Coefficient RAM address pointer. The first is to assert RESET\#, which automatically resets the pointer, but also clears the HDF and alters some of the control register bits. (RESET\# does not change any of the coefficient values.) The second method is to set the F_DIS bit in control register H_ REGISTER1. This control bit allows any of the FIR control register bits to be re-programmed, but does not automatically modify any control registers. When the programming is completed, the FIR is re-started by clearing the F__DIS bit or by asserting one of the start inputs (ASTARTIN\# or STARTIN\#). The F__DIS bit allows the filter parameters to be changed more quickly and is thus the recommended reprogramming method.

## Data RAM

The Data RAM stores the data needed for the filter calculation. The format of the data is:
$2^{0} .2^{-1} 2^{-2} 2^{-3} 2^{-4} 2^{-5} 2^{-6}-7_{2}-8_{2}-9_{2}-10_{2}-11_{2}-12_{2}-13_{2}-14_{2}-15$ where the sign bit is in the 20 location.

The 16 bit output of the HDF Output Register is written into the Data Ram on the rising edge of CK_DEC.
RESET\# initializes the write pointer to the data RAM. After a RESET\# occurs, the output of the FIR will not be valid until the number of new data samples written to the Data RAM equals TAPS.
The filter always operates on the most current sample and the taps -1 previous samples. Thus if the F__DIS bit is set, data continues to be written into the data RAM coming from the HDF section. When the FIR is enabled again the filter will be operating on the most current data samples and thus another transient response will not occur.
The maximum throughput of the FIR filter is limited by the use of a single Multiplier/Accumulator (MAC). The data output from the HDF being clocked into the FIR filter by CK_DEC must not be at a rate that causes an erroneous result being calculated because data is being overwritten.
The equation shown below describes the relationship between, FIR_CK, CK_DEC, the number of taps that can be implemented in the FIR, the decimation rate in the HDF and the decimation rate in the FIR. (In the Design Considerations section of the OPERATIONAL SECTION there is a chart that shows the tradeoffs between these parameters.)

$$
\begin{equation*}
\text { FIR_CK } \geq \frac{\mathrm{CK} \_\mathrm{IN}[(\mathrm{TAPS} / 2)+4+\mathrm{Fdec}]}{\text { Hdec Fdec }} \tag{1.0}
\end{equation*}
$$

This equation expresses the minimum FIR_CK. The minimum FIR__CK is the smallest integer multiple of CK_IN that satisfies equation 1.0. In addition, the TSK specification must be met (see A.C. Electrical Specifications). Fdec is the decimation rate in the FIR (Fdec = F_DRATE +1), where TAPS $=$ the number of taps in the FIR for even length filters and equals the number of taps +1 for odd length filters.

Solving the above equation for the maximum number of taps:
TAPS $=2\left(\frac{\text { FIR__CK Hdec Fdec }}{\text { CK_IN }}-\right.$ Fdec -4 $)$
In using this equation, it must be kept in mind that CK_IN/ Hec must be less than or equal to 4 MHz (unless the HDF is in bypass mode in which case this limitation in the HDF does not apply). In the OPERATIONAL SECTION under the Design Considerations, there is a table that shows the trade-offs of these parameters. In addition, Harris provides a software package called DECI•MATE ${ }^{\text {m }}$ which designs the DDF filter from System specifications.

The registered outputs of the data RAM are added or subtracted in the 17 bit pre-adder. The F_OAD control bit allows zeros to be input into one side of the pre-adder. This provides the capability to implement non-symmetric filters.

The selection of adding the register outputs for an even symmetric filter or for subtracting the register outputs for odd symmetric filter is provided by the control bit F__ESYM, which is programmed over the control bus. When subtraction is selected, the new data is subtracted from the old data. The 17 bit output of the adder forms one input of the multiplier/accumulator.

A control bit F_CLA provides the capability to clear the feedback path in the accumulator such that multiplier output will not be accumulated, but will instead flow directly to the output register. The bit weightings of the data and coefficients as they are processed in the FIR is shown below.

Input Data (from HDF) $2^{0} .2^{-1} \ldots 2^{-15}$
Pre-adder Output $2^{120} 2^{-1} \ldots 2^{-15}$
Coefficient 20.2-1 ... 2-19
Accumulator $2^{8} \ldots 2^{0} .2^{1} \ldots 2^{-34}$
FIR Output
The 40 most significant bits of the accumulator are latched into the output register. The lower 3 bits are not brought to the output. The 40 bits out of the output register are selected to be output by a pair of multiplexers. This register is clocked by FIR_CK (see Figure 9).

There are two multiplexers that route 24 of the 40 output bits from the output register to the output pins. The first multiplexer selects the output register bits that will be routed to output pins DATA_OUT16-23 and the second multiplexer selects the output register bits that will be routed to output pins DATA_OUTO-15.
The multiplexers are controlled by the control signal $\mathrm{F}_{\text {_ }}$ BYP and the OUT__SELH pin. F__BYP and OUT__SELH both control the first multiplexer that selects the upper 8 bits of the output bus, DATA __OUT16-23. F__BYP controls the second multiplexer that selects the lower 16 bits of the output bus, DATA__OUTO-15. The output formatter is shown in detail in Figure 10.

## FIR Control Logic

The DATA __RDY strobe indicates that new data is available on the output of the FIR. The rising edge of DATA__RDY can be used to load the output data into an external register or RAM.

## Data Format

The DDF maintains 16 bits of accuracy in both the HDF and FIR filter stages. The data formats and bit weightings are shown in Figure 11.

## Operational Section

## Start Configurations

The scenario to put the DDF into operational mode is: reset the DDF by asserting the RESET\# input, configure the DDF over the control bus, and apply a start signal, either by ASTARTIN\# or STARTIN\#. Until the DDF is put in operational mode with a start pulse, the DDF ignores all data inputs.

To use the asynchronous start, an asynchronous active low pulse is applied to the ASTARTIN\# input. ASTARTIN\# is internally synchronized to the sample clock, CK_IN, and generates STARTOUT\#. This signal is also used internally when the asynchronous mode is selected. It puts the DDF in operational mode and allows the DDF to begin accepting data. When the ASTARTIN\# input is being used, the STARTIN\# input must be tied high to ensure proper operation.

To start the DDF synchronously, the STARTIN\# is asserted with a active low pulse that has been externally synchronized to CK_IN. Internally the DDF then uses this start pulse to put the DDF in operate mode and start accepting data inputs. When STARTIN\# is used to start the DDF the ASTARTIN\# input must be tied high to prevent false starts.


## INPUT DATA FORMAT

Fractional Two's Complement Input

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## FIR COEFFICIENT FORMAT

Fractional Two's Complement Input

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- |
| $2^{-16} 2^{-17} 2^{-18} 2^{-19}$ |  |  |  |

## OUTPUT DATA FORMAT

Fractional Two's Complement Output
FOR: OUT__SELH = 1
$F \_B Y P=0$


FOR: OUT__SELH $=0$
$F_{\text {_BYP }}=0$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

FOR: OUT__SELH $=\mathbf{X}$
$F$ _BYP $=1$

| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $2-162-172_{2}-182_{2}-192-20_{2}-21_{2}-222_{2}-23$ |  |  |  |  |  |  |  |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

FIGURE 11.

## Multi-Chip Start Configurations

Since there are two methods to start up the DDF, there are also two configurations that can be used to start up multiple chips.
The first method is shown in Figure 12. The timing of the STARTOUT\# circuitry starts the second DDF on the same clock as the first. If more DDF's are also to be started synchronously, STARTOUT\# is connected to their STARTIN\#'s.

The second method to start up DDF's in a multiple chip configuration is to use the synchronous start scenario.

The STARTIN\# input is wired to all the chips in the chain, and is asserted by a active low synchronous pulse that has been externally synchronized to CK_IN. In this way all DDF's are synchronously started. The ASTARTIN\# input on all the chips is tied high to prevent false starts. The STARTOUT\# outputs are all left unconnected. This configuration is illustrated in Figure 13.


FIGURE 12. ASYNCHRONOUS START UP


FIGURE 13. SYNCHRONOUS START UP

## Chip Set Application

The HSP43220 is ideally suited for narrow band filtering in Communications, Instrumentation and Signal Processing applications. The HSP43220 provides a fully integrated solution to high order decimation filtering.

The combination of the HSP43220 and the HSP45116 (which is a NCOM Numerically Controlled Oscillator/ Modulator) provides a complete solution to digital receivers. The diagram in Figure 14 illustrates this concept.

The HSP45116 down converts the signal of interest to baseband, generating a real component and an imaginary
component. A HSP43220 then performs low pass filtering and reduces the sampling rate of each of the signals.
The system scenario for the use of the DDF involves a narrow band signal that has been over-sampled. The signal is over-sampled in order to capture a wide frequency band containing many narrow band signals. The NCOM is "tuned" to the frequency of the signal of interest and performs a complex down conversion to baseband of this signal, which results in a complex signal centered at baseband. A pair of DDF's then low pass filters the NCOM output, extracting the signal of interest.


FIGURE 14. DIGITAL CHANNELIZER

## Design Trade-Off Considerations

Equation 2.0 in the Functional Description section expresses the relationship between the number of TAPS which can be implemented in the FIR as a function of CK_IN, FIR_CK, Hdec, Fdec. Figure 15 provides a
tradeoff of these parameters. For a given speed grade and the ratio of the clocks, and assuming minimum decimation in the HDF, the number of FIR taps that can be implemented is given in equation 2.0.

| $\begin{aligned} & \text { SPEED } \\ & \text { GRADE (MHz) } \end{aligned}$ | $\frac{\text { FIR__CK }}{\mathbf{C K} \_\mathbb{I N}}$ | MIN <br> Hdec | TAPS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fdec $=1$ | Fdec $=2$ | Fdec $=4$ | Fdec $=8$ | Fdec $=16$ |
| 33 | 1 | 9 | 8 | 24 | 56 | 120 | 248 |
| 25.6 | 1 | 7 | 4 | 16 | 40 | 88 | 184 |
| 15 | 1 | 4 | * | 4 | 16 | 40 | 88 |
| 33 | 2 | 5 | 10 | 28 | 64 | 136 | 280 |
| 25.6 | 2 | 4 | 6 | 20 | 48 | 104 | 216 |
| 15 | 2 | 2 | * | 4 | 16 | 40 | 88 |
| 33 | 4 | 3 | 14 | 36 | 80 | 168 | 344 |
| 25.6 | 4 | 2 | 6 | 20 | 48 | 104 | 216 |
| 15 | 4 | 1 | * | 4 | 16 | 40 | 88 |
| 33 | 8 | 2 | 22 | 52 | 112 | 232 | 472 |
| 25.6 | 8 | 1 | 6 | 20 | 48 | 104 | 216 |
| 15 | 8 | 1 | 6 | 20 | 48 | 104 | 216 |

* Filter Not Realizable

FIGURE 15. DESIGN TRADE OFF FOR MINIMUM Hdec

## DECI•MATE

Harris provides a development system which assists the design engineer to utilizing this filter. The DECI - MATE software package provides the user with both filter design and simulation environments for filter evaluation and design. These tools are integrated within one standard DSP CAD environment, The Athena Group's Monarch Professional DSP Software package.
The software package is designed specifically for the DDF. It provides all the filter design software for this proprietary architecture. It provides a user-friendly menu driven interface to allow the user to input system level filter requirements. It provides the frequency response curves and a data flow simulation of the specified filter design (Figure 16). It also creates all the information necessary to program the DDF, including a PROM file for programming the control registers.

This software package runs on an $I B M^{m} P^{m w}, X T^{m}, A T^{m}$, PS $/ 2^{m}$ computer or $100 \%$ compatible with the following configuration:

## 640K RAM

$5.25^{\prime \prime}$ or $3.5^{\prime \prime}$ Floppy drive
hard disk
math co-processor
MS/PC-DOS 2.0 or higher
CGA, MCGA, EGA, VGA and
Hercules graphics adapters

For more information, see the description of DECI-MATE in the Development Tools Section of this databook.

## HSP43220 DDF FILTER SPECIFICATION

| Filter File | : | vectors 1 example. DDF |  |  |
| :--- | ---: | ---: | :--- | :--- | :--- |
| Input Sample Rate: | 33 MHz | Design Mode | AUTO |  |
| Output Rate | $:$ | 100 kHz | Generate Report | YES |
| Passband | 20 kHz | Display Response | LOG |  |
| Transition Band | $:$ | 7.5 kHz | Save Freq Responses: | YES |
| Passband Atten | $:$ | 0.5 dB | Save FIR Response | YES | FIR Type : PRECOMP


| HDF | Order | : | 4 | FIR | Input Rate | : | 300 | kHz |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HDF | Decimation | : | 110 | FIR | Clock (min) | : | 33 | MHz |
| HDF | Scale Factor | : | 0.54542 | FIR | Order | : | 135 |  |
|  |  |  |  | FIR | Decimation | : | 3 |  |



FIGURE 16. DECI•MATE DESIGN MODULE SCREENS

| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or V/O Voltage Applied. | GND -0.5V to $\mathrm{V}_{\text {cc }}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature |  |
| PGA | $+175^{\circ} \mathrm{C}$ |
| PLCC | $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| :---: | :---: | :---: |
| PGA Package | $32.9{ }^{\circ} \mathrm{CN}$ | $7.2^{\circ} \mathrm{C} / \mathrm{N}$ |
| MQFP | $33.0^{\circ} \mathrm{CN}$ | $13.5{ }^{\circ} \mathrm{CN}$ |
| PLCC. | $33.8^{\circ} \mathrm{CN}$ | $10.9{ }^{\circ} \mathrm{CN}$ |
| Maximum Package Power Dissipation |  |  |
| PGA. |  | . 3.2W |
| MQFP |  | 2.4W |
| PLCC. |  | 2.4W |
| Component Count. | 193,000 | ansistors |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

Operating Conditions
Operating Voltage Range . . . . . . . . . . . . . . . . . . +4.75 V to +5.25 V Operating Temperature Range $\ldots \ldots \ldots \ldots . . . . . . . . . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $\bullet$ | 0.8 | V | $\mathrm{V}_{\text {cC }}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | VILC | - | 0.8 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| I/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $l_{\text {ccse }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{C C}$ or $\mathrm{GND} \mathrm{V}_{C C}=5.25 \mathrm{~V}$, Note 3 |
| Operating Power Supply Current | I'cop | - | 120 | mA | $\begin{aligned} & f=15 \mathrm{MHz}, V_{I N}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V} \\ & \text { Notes } 1 \text { and } 3 \end{aligned}$ |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Note 2

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{cc}}=$ Open, All measure- <br> ments are referenced to device ground |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 10 | pF |  |

NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for $I_{\text {ccop }}$ is $8 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
3. Output load per test load circuit with switch open and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | -15 |  | -25 |  | -33 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| Input Clock Frequency | FCK | 0 | 15 | 0 | 25.6 | 0 | 33 | MHz |  |
| FIR Clock Frequency | FFIR | 0 | 15 | 0 | 25.6 | 0 | 33 | MHz |  |
| Input Clock Period | ${ }^{\text {TCK }}$ | 66 | - | 39 | - | 30 | - | ns |  |
| FIR Clock Period | T FIR | 66 | - | 39 | - | 30 | - | ns |  |
| Clock Pulse Width Low | TSPWL | 26 | - | 16 | - | 13 | - | ns |  |
| Clock Pulse Width High | $\mathrm{T}_{\text {SPWH }}$ | 26 | - | 16 | - | 13 | - | ns |  |
| Clock Skew Between FIR_CK and CK_IN | TSK | 0 | $\mathrm{T}_{\text {FIR }}{ }^{-25}$ | 0 | $\mathrm{T}_{\mathrm{FIR}}{ }^{-15}$ | 0 | $\mathrm{T}_{\text {FIR }}{ }^{-15}$ | ns |  |
| CK_IN Pulse Width Low | $\mathrm{T}^{\text {CH1L }}$ | 29 | - | 19 | - | 19 | - | ns | Note 1, Note 4 |
| CK_IN Puise Width High | ${ }^{\text {T }} \mathrm{CH} 1 \mathrm{H}$ | 29 | - | 19 | - | 19 | - | ns | Note 1, Note 4 |
| CK_IN Setup to FIR_CK | TCIS | 27 | - | 17 | - | 17 | - | ns | Note 1, Note 4 |
| CK_IN Hold from FIR_CK | ${ }^{\text {T }}$ CIH | 2 | - | 2 | - | 2 | - | ns | Note 1, Note 4 |
| RESET\# Pulse Width Low | TRSPW | ${ }^{4} \mathrm{CK}$ | - | ${ }^{4 T} \mathrm{CK}$ | - | ${ }^{4} \mathrm{TCK}$ | - | ns |  |
| Recovery Time on RESET\# | TRTRS | ${ }^{81} \mathrm{CK}$ | - | $8 \mathrm{~T}_{\mathrm{CK}}$ | - | ${ }^{81} \mathrm{CK}$ | - | ns |  |
| ASTARTIN\# Pulse Width Low | TAST | TCK+10 | - | $\mathrm{T}_{\mathrm{CK}+10}$ | - | ${ }^{T} \mathbf{C K}+10$ | - | ns |  |
| STARTOUT\# Delay from CK_IN | TSTOD | - | 35 | - | 20 | - | 18 | ns |  |
| STARTIN\# Setup to CK_IN | TSTIC | 25 | - | 15 | - | 10 | - | ns |  |
| Setup Time on DATA_IN | TSET | 20 | - | 15 | - | 14 | - | ns |  |
| Hold Time on All inputs | THOLD | 0 | - | 0 | - | 0 | - | ns |  |
| Write Pulse Width Low | TWL | 26 | - | 15 | - | 12 | - | ns |  |
| Write Pulse Width High | TWH | 26 | - | 20 | - | 18 | - | ns |  |
| Setup Time on Address Bus Before the Rising Edge of Write | Tstadd | 26 | - | 20 | - | 20 | - | ns |  |
| Setup Time on Chip Select Before the Rising Edge of Write | Tstcs | 26 | - | 20 | - | 20 | - | ns |  |
| Setup Time on Control Bus Before the Rising Edge of Write | Tstcb | 26 | - | 20 | - | 20 | - | ns |  |
| DATA_RDY Pulse Width Low | TDRPWL | ${ }^{2 T} \mathrm{FIR}^{-20}$ | - | ${ }^{2} \mathrm{FFRR}^{-10}$ | - | ${ }^{2} \mathrm{FFIR}^{-10}$ | - | ns |  |
| DATA_OUT Delay Relative to FIR_CK | T ${ }_{\text {FIRDV }}$ | - | 50 | - | 35 | - | 28 | ns |  |
| DATA RDY Valid Delay Relative to FIR_CK | TFIRDR | - | 35 | - | 25 | - | 20 | ns |  |
| DATA_OUT Delay Relative to OUT__SELH | TOUT | - | 25 | - | 20 | - | 20 | ns |  |
| Output Enable to Data Out Valid | TOEV | - | 15 | - | 15 | - | 15 | ns | Note 2 |
| Output Disable to Data Out Three State | ToEZ | - | 15 | - | 15 | - | 15 | ns | Note 1 |
| Output Rise, Output Fall Times | $T_{R}, T_{F}$ | - | 8 | - | 8 | - | 6 | ns | from .8 V to 2 V , Note 1 |

NOTES:

1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with and $C_{L}=40 \mathrm{pF}$.
3. A.C. Testing is performed as follows: Input levels (CLK Input) 4.0 V and OV , Input levels (all other Inputs) $O V$ and 3.0 V , Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$, Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
4. Applies only when $H_{\ldots} \quad B Y P=1$ or $H \_$DRATE $=0$.


DC Electrical Specifications $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 . | $\stackrel{\square}{ }$ | V | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $\checkmark$ | 0.8 | V | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6. | * | V | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 1) |
| Output LOW Voltage | $\mathrm{V}_{\text {OL }}$ | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 1) |
| Input Leakage Current | 1 | -10. | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10. | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{HC}}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | - | 08 | V | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ |
| Standby Power Supply Current | $l_{\text {ccss }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, Outputs Open |
| Operating Power Supply Current | $\mathrm{I}_{\text {CCOP }}$ | - | 120 | mA | $\mathrm{f}=15 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ (Note 2) |
| Functional Test | FT | - | $\stackrel{+}{*}$ |  | (Note 3) |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $\mathrm{f}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

AC Electrical Specifications $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | $-15(15 \mathrm{MHz})$ |  | 25 (25.6MHz) |  | UNITS | (NOTE 1) CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | MAX | MiN | MAX |  |  |
| Input Clock Period | $\mathrm{T}_{\text {ck }}$ | 66 | $\stackrel{ }{ }$ | 39 | - | ns |  |
| FIR Clock Period | $\mathrm{T}_{\text {FIR }}$ | 66 | F ${ }^{\text {a }}$ | 39 | $\cdots$ | ns |  |
| Clock Pulse Width Low | $\mathrm{T}_{\text {SPWL }}$ | 26 | $\checkmark$ | 16. | - | ns |  |
| Clock Pulse Width High | $\mathrm{T}_{\text {SPWH }}$ | 26 | - | 16. | - | ns |  |
| Clock Skew Between FIR_CK and CK_IN | $\mathrm{T}_{\text {SK }}$ | 0 | $\mathrm{T}_{\text {FiR }}$ - 25 | 0 | Tin- 19 | ns |  |
| RESET\# Pulse Width Low | $\mathrm{T}_{\text {RSPW }}$ | ${ }^{4} \mathrm{Tck}$ | $\cdot$ | 4 Cck | $\cdot$ | ns |  |
| Recovery Time On RESET\# | T ${ }_{\text {RTRS }}$ | $8 \mathrm{ck}_{\text {ck }}$ | $\checkmark$ | $8^{1} \mathrm{ck}$ | $\cdots$ | ns |  |
| ASTARTIN\# Pulse Width Low | $\mathrm{T}_{\text {AST }}$ | TCk +10 | - | T $\mathrm{ck}+10$ | - | ns |  |
| STARTOUT\# Delay From CK_IN | $\mathrm{T}_{\text {STOD }}$ | * | 35 | - | 20 | ns |  |
| STARTIN\# Setup To CK_IN | $\mathrm{T}_{\text {STIC }}$ | 25 | - | 15 | - | ns |  |

## AC Electrical Specifications $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (ContInued)

| PARAMETER | SYMBOL | 15 ( 15 MHz ) |  | 25 (25.6M14z) |  | UNITS | (NOTE 1) CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MiN | MAX |  |  |
| Setup Time on DATA_IN | $\mathrm{T}_{\text {SET }}$ | 20 | - | 16 | - | ns |  |
| Hold Time on All Inputs | $\mathrm{T}_{\text {HOL }}$ | 0 | - | 0 | \% | ns |  |
| Write Pulse Width Low | $T_{\text {WL }}$ | 26 | - | 15 | - | ns |  |
| Write Pulse Width High | $T_{\text {WH }}$ | 26 | * | 20 | . | ns |  |
| Setup Time on Address Bus Before the Rising Edge of Write | $\mathrm{T}_{\text {Stad }}$ | 28 |  | $24$ |  | ns |  |
| Setup Time on Chip Select Before the Rising Edge of Write | $\mathrm{T}_{\text {STCS }}$ | 28 |  | \% 24 |  | ns |  |
| Setup Time on Control Bus Before the Rising Edge of Write | $\mathrm{T}_{\text {STCB }}$ | $28$ |  | $24$ |  | ns |  |
| DATA_RDY Puise Width Low | $\mathrm{T}_{\text {DRPWL }}$ | 2 Trir $^{20}$ | ! | 2TFR-10 | . | ns |  |
| DATA_OUT Delay Relative to FIR_CK | $\mathrm{T}_{\text {FIROV }}$ | . | 50 | - | 35 | ns |  |
| DATA_RDY Valid Delay Relative to FIR_CK | T FIRDR | - | 35 | . | 25 | ns |  |
| DATA_OUT Delay Relative to OUT_SELH | Tout | - | 30 | ¢ | 25 | ns |  |
| Output Enable to Data Out Valid | ToEV | \% | 20 | - | 20 | ns | (Note 2) |

NOTES:

1. $A C$ Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and 0 V and measured at 2.0 V .
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

Electrical Specifications $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | NOTES | -15 |  | 25 |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MiN | MAX |  |  |
| CK_IN Pulse Width Low | $\mathrm{T}_{\text {CHIL }}$ | 1,3 | 29 | - | 19 | T | ns |  |
| CK_IN Pulse Width High | $\mathrm{T}_{\text {CHIH }}$ | 1,3 | 29 |  | 19 | . | ns |  |
| CK_IN Setup to FIR_CK | $\mathrm{T}_{\text {CIS }}$ | 1,3 | 27. | - | 17 | . | ns |  |
| CK_IN Hold from FIR_CK | $\mathrm{T}_{\text {CIH }}$ | 1,3 | 2 | \%. | \% 2 | \% | ns |  |
| Output Disable Delay | Toez | 1,2 | $\stackrel{ }{ }$ | 20 | - | 20 | ns |  |
| Output Rise Time | TOR | 1,2 | S. | 8 | . | 8 | ns |  |
| Output Fall Time | $\mathrm{T}_{\text {OF }}$ | 1,2 | . | 8 | \%. | 8 | ns |  |

## NOTES:

1. The parameters in this table are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Applies only when $H_{\_} B Y P=1$ or $H_{-}$DRATE $=0$.


Switch Si Open for ICCSB and ICCOP Tests

## Timing Waveforms

input timing


START TIMING


## Timing Waveforms (Continued)

## OUTPUT TIMING



## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Single Chip Narrow Band Filter with up to 96dB Attenuation
- DC to 25.6MHz Clock Rate
- 16-Bit 2's Complement Input
- 20-Bit Coefficients in FIR
- 24-Bit Extended Precision Output
- Programmable Decimation up to a Maximum of 16,384
- Standard 16-Bit Microprocessor Interface
- Filter Design Software Available DECl•MATETM


## Applications

- Very Narrow Band Filters
- Zoom Spectral Analysis
- Channelized Receivers


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :--- |
| HSP43220GM-15/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP43220GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The HSP43220/883 Decimating Digital Filter is a linear phase low pass decimation filter which is optimized for and filtering narrow band signals in a broad spectrum of a signal processing applications. The HSP43220/883 offers a single chip solution to signal processing application which have historically required several boards of IC's. This reduction in component count results in faster development times as well as reduction of hardware costs.

The HSP43220/883 is implemented as a two stage filter structure. As seen in the block diagram, the first stage is a high order decimation filter (HDF) which utilizes an efficient decimation (sample rate reduction) technique to obtain decimation up to 1024 through a coarse low-pass filtering process. The HDF provides up to 96 dB aliasing rejection in the signal pass band. The second stage consists of a finite impulse response (FIR) decimation filter structured as a transversal FIR filter with up to 512 symmetric taps which can implement filters with sharp transition regions. The FIR can perform further decimation by up to 16 if required while preserving the 96 dB aliasing attenuation obtained by the HDF. The combined total decimation capability is 16,384 .
The HSP43220/883 accepts 16-bit parallel data in 2's complement format at sampling rates up to 30MSPS. It provides a 16-bit microprocessor compatible interface to simplify the task of programming and three-state outputs to allow the connection of several IC's to a common bus. The HSP43220/883 also provides the capability to bypass either the HDF or the FIR for additional flexibility.

## Block Diagram



DECl $\odot$ MATE ${ }^{\mathrm{m}}$ is a registered trademark of Harris Corporation.
IBM PC ${ }^{\text {TM }}$, XT $^{\text {TM }}, ~ A T^{T M}, ~ P S / 2^{T M}$ are registered trademarks of International Business Machines, inc.


## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $32.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $7.2{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe Ceramic PGA Package | $t+125^{\circ} \mathrm{C}$ | 1.52 Wat |
| ate Count |  | ,250 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
Operating Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125{ }^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}^{\mathrm{O}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | II | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 V \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{\text {CC }} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ICCSB | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & \mathrm{f}=15.0 \mathrm{MHz} \\ & \mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | 120.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

Specifications HSP43220/883

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -15 (15MHz) |  | -25 (25.6MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Clock Period | TCK |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| FIR Clock Period | $\mathrm{T}_{\text {FIR }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| Clock Pulse Width Low | TSPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 16 | - | ns |
| Clock Pulse Width High | $\mathrm{T}_{\text {SPWH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 16 | - | ns |
| Clock Skew Between FIR_CK and CK_IN | TSK |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | $\begin{aligned} & T_{\text {FIR }} \\ & -25 \end{aligned}$ | 0 | $\begin{aligned} & T_{\text {FIR }} \\ & -19 \end{aligned}$ | ns |
| RESET\# Pulse Width Low | $\mathrm{T}_{\text {RSPW }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | ${ }^{4 T} \mathrm{CK}$ | - | ${ }^{4 T} \mathrm{CK}$ | - | ns |
| Recovery Time On RESET\# | ${ }^{\text {TRTRS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | ${ }^{87} \mathrm{CK}$ | - | ${ }^{87} \mathrm{CK}$ | - | ns |
| ASTARTIN\# Pulse Width Low | ${ }^{\text {T }}$ AST |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \mathrm{T}_{\mathrm{CK}} \\ & +10 \end{aligned}$ | - | $\begin{aligned} & \mathrm{T} C K \\ & +10 \\ & \hline \end{aligned}$ | - | ns |
| STARTOUT\# Delay From CK_IN | TSTOD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 20 | ns |
| STARTIN\# Setup To CK_IN | ${ }^{\text {TStic }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 15 | - | ns |
| Setup Time on DATA_IN | TSET |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Hold Time on All Inputs | THOLD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Write Pulse Width Low | TWL |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| Write Puise Width High | TWH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 20 | - | ns |
| Setup Time on Address Bus Before the Rising Edge of Write | TSTADD |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| Setup Time on Chip Select Before the Rising Edge of Write | TSTCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| Setup Time on Control Bus Before the Rising Edge of Write | Tstcb |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| DATA_RDY Pulse Width Low | TDRPWL |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & 2 T_{\text {FIR }} \\ & -20 \end{aligned}$ | - | $\begin{gathered} { }^{2 T_{\text {FIR }}} \\ -10 \end{gathered}$ | - | ns |
| DATA_OUT Delay Relative to FIR_CK | T FIRDV |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | - | 35 | ns |
| DATA_RDY Valid Delay Relative to FIR_CK | T FIRDR |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 25 | ns |
| DATA_OUT Delay Relative to OUT_SELH | TOUT |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 25 | ns |
| Output Enable to Data Out Valid | ToEV | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |

NOTES:

1. A.C. Testing: $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic "1" and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $C_{L}=40 p F$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -15 (15MHz) |  | -25 (25.6MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CK_IN Pulse Width Low | $\mathrm{T}_{\text {CH1L }}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 29 | - | 19 | - | ns |
| CK_IN Pulse Width High | TCH1H |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 29 | - | 19 | - | ns |
| CK_IN Setup to FIR_CK | TCIS |  | 1,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 27 | - | 17 | - | ns |
| CK_IN Hold from FIR_CK | ${ }^{\text {T }} \mathrm{ClH}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| Input Capacitance | $\mathrm{CIN}^{\text {N }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Open, } \\ & \mathrm{f}=1 \mathrm{MHz}, \mathrm{All} \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Capacitance | Cout | $\begin{aligned} & V_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, \text { All } \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Disable Delay | ToEz |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

## NOTES:

1. Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.
3. Applies only when H _BYP $=1$ or H __DRATE $=0$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

HSP43220/883

| Burn-In Circuit |  |  | 1 | 2 | 3 | 4 | 5 | - | 7 | : | - | 10 | 11 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\wedge$ | al | ${ }_{\text {ind }}^{\text {math }}$ | infa | infe |  | - ${ }_{\text {int }}^{\text {ind }}$ | data- | dita | $v_{c c}$ | gnd | and |  |
|  |  | ${ }^{\text {B }}$ | ¢ | Stant | NaTh | - ${ }_{\text {infa }}$ | DiNe ${ }^{\text {din }}$ | ${ }^{\text {in }} 13$ | indin | ${ }_{\text {dit }}^{\text {dit }}$ | ckin | vcc |  |  |
|  |  | $c$ |  | $\mathrm{v}_{\mathrm{cc}}$ |  |  |  | $\underline{\text { and }}$ | (into |  |  | - | $\begin{array}{\|l\|l\|l\|l\|} \text { onta } \\ \text { our } \end{array}$ |  |
|  |  | - | ${ }^{\wedge}$ | Resst |  | HSP43220 <br> rom ylew <br> PINSOOMN: |  |  |  |  |  | $\left\|\begin{array}{l} \text { DATM } \\ \text { Out } 3 \end{array}\right\|$ | дата |  |
|  |  | E | cs \% | wher | ^о |  |  |  |  |  | $\begin{aligned} & \text { onta } \\ & \text { ours } \end{aligned}$ | DATA. $\text { OUT } 6$ | $\begin{array}{\|l\|l\|} \hline \text { onian } \\ \text { out } 7 \end{array}$ |  |
|  |  | F | ${ }^{\text {c._us }} 10$ | $\left\|\begin{array}{c} \text { c_eus } \\ 15 \end{array}\right\|$ | C-bus |  |  |  |  |  | onta | vcc | $\left.\begin{array}{\|c\|} \hline \text { ata } \\ \text { OUT } \end{array} \right\rvert\,$ |  |
|  |  | c | $C_{12}$ | c_ous | $\begin{gathered} c_{- \text {_ous }}^{13} \\ \hline 1 \end{gathered}$ |  |  |  |  |  | $\begin{aligned} & \text { Data } \\ & \text { out } 10 \end{aligned}$ | and | ditan |  |
|  |  | ${ }^{+}$ | c_-qus | $\mathrm{v}_{\mathrm{cc}}$ |  |  |  |  |  |  |  | $\begin{array}{\|l\|} \hline \text { ontr } \\ \text { Ouf } 13 \end{array}$ | onth our 12 oun |  |
|  |  | , | ¢no | $\left\|\begin{array}{c} \text { c_sus } \\ 7 \end{array}\right\|$ |  |  | $\begin{aligned} & \text { OUR } \\ & \text { SEL } \end{aligned}$ | ond | ${ }_{c k}^{\mathrm{fri}}$ |  |  | $\begin{aligned} & \text { DATA } \\ & \text { OUT } 16 \end{aligned}$ | oata <br> out 14 |  |
|  |  | $\kappa$ | ${ }_{\text {c a }}^{8} \mathrm{Bus}$ | ${ }^{\text {c-aus }}$ | $\text { s } \begin{gathered} c_{1}-\text { gus } \\ \hline \end{gathered}$ | c-sus | $\left\|\begin{array}{l} \text { our } \\ \text { ENP } \# * \end{array}\right\|$ | $v_{\text {cc }}$ | and | $\left.\begin{array}{\|c\|} \hline \text { Ditit } \\ \text { out } 22 \end{array} \right\rvert\,$ | $\begin{array}{\|l\|} \hline \text { OAIN } \\ \text { OUT } 19 \\ \hline \end{array}$ | $\left\lvert\, \begin{array}{\|l\|l\|} \hline \text { OATM } \\ \text { Out } 17 \end{array}\right.$ | data <br> out |  |
|  |  | 4 | C-_sus | ${ }^{\text {c-sus }}$ | s ${ }_{\text {c-eves }}^{2}$ | $\overline{c-\operatorname{sus}}$ |  | $\left\lvert\, \begin{array}{\|c\|c\|} \hline \text { oninan } \\ \text { and } \end{array}\right.$ RDY | vcc | $\begin{aligned} & \text { DATA } \\ & \text { OUT 23 } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { DATA } \\ \text { OUT } 21 \end{array}$ | $2 \begin{aligned} & \text { DATA } \\ & \text { Out } 20 \end{aligned}$ | $\begin{aligned} & \text { DATA } \\ & \text { OUT } 1 E \end{aligned}$ |  |
| $\begin{aligned} & \text { PIN } \\ & \text { LEAD } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |  |  | $\begin{aligned} & \text { PIN } \\ & \text { LEAD } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \\ \hline \end{gathered}$ |  |  | BURN-IN SIGNAL |  |  | $\begin{gathered} \text { PIN } \\ \text { LEAD } \\ \hline \end{gathered}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| A1 | GND | GND |  |  | G1 | ASTARTIN\# |  |  | F15 |  |  | F11 | DATA_OUT3 | $\mathrm{vCC}^{\prime}$ |
| A2 | DATA_IN 1 | F2 |  |  | C2 | $\mathrm{V}_{\text {CC }}$ |  |  | $\mathrm{V}_{\mathrm{CC}}$ |  |  | G1 | C_BuS 12 | F5 |
| A3 | DATA IN 2 | F3 |  |  | C5 | DATA_IN 5 |  |  | F6 |  |  | G2 | C_BuS 11 | F4 |
| A4 | DATA_IN 4 | F5 |  |  | C6 | DATA_IN9 |  |  | F2 |  |  | G3 | C_BUS 13 | F6 |
| A5 | DATA_IN 7 | F8 |  |  | C7 | DATA_IN 10 |  |  | F3 |  |  | G9 | DATA_OUT 10 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| A6 | DATA_IN 8 | F1 |  |  | C10 | data_outo |  |  | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  | G10 | GND | GND |
| A7 | DATA_IN 11 | F4 |  |  | C11 | DATA_OUT 2 |  |  | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  | G11 | DATA_OUT 11 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| A8 | DATA_IN 14 | F7 |  |  | D1 | A1 |  |  | F14 |  | H1 | 41 | C_Bus 9 | F2 |
| A9 | $\mathrm{v}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ |  |  | D2 | RESET\# |  |  | F16 |  | H2 | 42 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{C C}$ |
| A10 | GND | GND |  |  | D10 | DATA_OUT 3 |  |  | $\mathrm{V}_{\mathrm{CC} / 2}$ |  |  | 410 | DATA_OUT 13 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A11 | GND | GND |  |  | D11 | DATA_OUT 4 |  |  | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  | 411 | DATA_OUT 12 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B1 | STARTIN\# | F15 |  |  | E1 | CS\# |  |  | F11 |  | J1 | 1 | GND | GND |
| B2 | Startout | $\mathrm{V}_{\mathrm{CC} / 2}$ |  |  | E2 | WR\# |  |  | F11 |  | J2 | 2 | C_Bus 7 | F8 |
| B3 | dATA_INO | F1 |  |  | E3 | AO |  |  | F13 |  | J5 | 5 | OUT_SELH | F10 |
| B4 | DATA_IN 3 | F4 |  |  | E9 | DATA_OUT 5 |  |  | $\mathrm{v}_{\mathrm{CC} / 2}$ |  | J6 | 6 | GND | GND |
| B5 | DATA IN 6 | F7 |  |  | E10 | DATA_OUT 6 |  |  | $v_{C C / 2}$ |  | J8 |  | FIR_CK | FO |
| B6 | DATA_IN 13 | F6 |  |  | E11 | DATA_OUT 7 |  |  | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  | 10 | DATA_OUT 16 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B7 | DATA_IN 12 | F5 |  |  | F1 | C_BUS 10 |  |  | F3 |  | J1 | 11 | DATA_OUT 14 | $\mathrm{VCC}^{\prime} / 2$ |
| B8 | DATA_IN 15 | F8 |  |  | F2 | C_Cbus 15 |  |  | F8 |  | K1 |  | C_BUS 8 | F1 |
| B9 | CK_IN | Fo |  |  | F3 | C_BUS 14 |  |  | F7 |  | K2 | 2 | C_BUS 5 | F6 |
| B10 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\text {cc }}$ |  |  | F9 | DATA_OUT9 |  |  | $\mathrm{V}_{\mathrm{CC} / 2}$ |  | K3 | 3 | C_bus 4 | F5 |
| B11 | DATA_OUT1 | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  | F10 | $\mathrm{V}_{\text {cc }}$ |  |  | $\mathrm{v}_{\text {cc }}$ |  | K4 | K | c_bus 1 | F2 |
| NOTES: <br> 1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only. <br> 5. $F O=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots \ldots F 16=F 15 / 2,40 \%-60 \%$ <br> 2. $\mathbf{4 7 K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND. <br> 3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$. <br> 6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8$ max, $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$. <br> 4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Burn-In Circuit (Continued)

| $\begin{aligned} & \text { PIN } \\ & \text { LEAD } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| K5 | OUT__ENP\# | F9 |
| K6 | $V_{C C}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| K7 | GND | GND |
| K8 | DATA _OUT 22 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| K9 | DATA_OUT 19 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| K10 | DATA__OUT 17 | $\mathrm{V}_{\mathrm{CC} / 2}$ |


| PIN <br> LEAD | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| K11 | DATA_OUT 15 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| L1 | C__BUS 6 | F7 |
| L2 | C_BUS 3 | F4 |
| L3 | C__BUS 2 | F3 |
| L4 | C__BUS 0 | F1 |
| L5 | OUT_ENX\# | F9 |


| PIN <br> LEAD | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| L6 | DATA_RDY\# | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| L7 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| L8 | DATA_OUT 23 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| L9 | DATA_OUT 21 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| L10 | DATA_OUT 20 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| L11 | DATA_OUT 18 | $\mathrm{V}_{\mathrm{CC}} / 2$ |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and $G N D$.
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{v}$.
4. $0.1 \mu \mathrm{~F}$ (min) capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, \mathrm{~F}_{1}=\mathrm{FO} / 2, F 2=F 1 / 2 \ldots . \mathrm{F}_{1}=\mathrm{F} 15 / 2,40 \%-60 \%$ Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8$ max, $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Metal Topology

DIE DIMENSIONS:
$348 \times 349.2 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or Si - Al - Cu
Thickness: $8 \mathrm{k} \AA$

WORST CASE CURRENT DENSITY:
$1.18 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

Metallization Mask Layout
HSP43220/883


## Features

- Four Filter Cells
- OMHz to 30 MHz Sample Rate
- 8-Bit Coefficients and Signal Data
- 26-Bit Accumulator per Stage
- Filter Lengths Up to 1032 Tap
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2,3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP43481JC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP43481JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP43481JC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP43481GC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP43481GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP43481GC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HSP43481 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of four filter cells cascaded internally and a shift-and-add output stage, all in a single integrated circuit. Each filter cell contains an $8 \times 8$ multiplier, three decimation registers and a 26 -bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by eight-bits. The HSP43481 has a maximum sample rate of 30 MHz . The effective multiplyaccumulate (MAC) rate is 120 MHz .
The HSP43481 can be configured to process expanded coefficient and word sizes. Multiple devices can be cascaded for larger filter lengths without degrading the sample rate or a single device can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The HSP43481 provides for unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.
Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as $\mathrm{N} \times \mathrm{N}$ spatial correlations/convolutions for image processing applications.

## Block Diagram




68 PIN PLASTIC LEADED CHIP CARRIER (PLCC)
TOP VIEW


## Pin Description

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $v_{\text {cc }}$ | 61 |  | +5V Power Supply Input |
| $V_{S S}$ | 27 |  | Power Supply Ground Input |
| CLK | 19 | I | The CLK input provides the DF system sample clock. The maximum clock frequency is is 30 MHz . |
| DINO-7 | $\begin{gathered} 64-68 \\ 1-3 \end{gathered}$ | 1 | These eight inputs are the data sample input bus. Eight bit data samples are synchronously loaded through these pins to the $X$ register of each filter cell simultaneously. <br> The DIENB signal enables loading, which is synchronous on the rising edge of the clock signal. |
| TCS | 4 | 1 | The TCS input determines the number system interpretation of the data input samples on pins DINO-7 as follows: <br> TCS $=$ Low $\rightarrow$ Unsigned Arithmetic <br> TCS $=$ High $\rightarrow$ Two's Complement Arithmetic <br> The TCS signal is synchronously loaded into the $X$ register in the same way as the DINO-7 inputs. |
| $\overline{\text { DIENB }}$ | 5 | 1 | A low on this enables the data sample input bus (DINO-7) to all the filter cells. A rising edge of the CLK signal occurring while DIENB is low will load the $X$ register of every filter cell with the 8 bit value present on DINO-7. A high on this input forces all the bits of the data sample input bus to zero; a rising CLK edge when DTENB is high will load the X register of every filter cell with all zeros. This signal is latched inside the DF, delaying its effect by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired data on the DINO-7 inputs. Detailed operation is shown in later timing diagrams. |
| CINO-7 | 53-60 | I | These eight inputs are used to input the 8 bit coefficients. The coefficients are synchronously synchronously loaded into the C register of filter Cell O if a rising edge of CLK occurs while CIENB is low. The CIENB signal is delayed by one clock as discussed below. |
| TCCI | 62 | I | The TCCl input determines the number system interpretation of the coefficient inputs on pins CINO-7 as follows: <br> TCCI $=$ LOW $\rightarrow$ Unsigned Arithmetic <br> TCCI $=$ HIGH $\rightarrow$ Two's Complement Arithmetic <br> The TCCI signal is synchronously loaded into the $C$ register in the same way as the CINO-7 inputs. |
| $\overline{\text { CIENB }}$ | 63 | 1 | A low on this input enable the $C$ register of every filter cell and the $D$ registers (decimation) of every filter cell according to the state of the DCMO-1 inputs. A rising edge of the CLK signal occurring while CIENB is low will load the C register and appropriate D registers with the coefficient data present at their inputs. This privides the mechanism for shifting the coefficients from cell to cell through the device. A high on this input freezes the contents of the C register and the D registers, ignoring the CLK signal. This signal is latched and delayed by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired coefficient on the CINO-7 inputs. Detailed operation is shown in the Timing Diagrams section. |
| COUTO-7 | 10-17 | 0 | These eight three-state outputs are used to output the 8 bit coefficients from filter cell 7. These outputs are enabled by the COENB signal low. These outputs may be tied to the CINO-7 inputs of the same DF to recirculate the coefficients, or they may be tied to the CINO-7 inputs of another DF to cascade DFs for longer filter lengths. |
| TCCO | 9 | 0 | The TCCO three-state output determines the number system representation of the coefficients output on COUTO-7. It tracks the TCCI signal to this same DF. It should be tied to the TCCI input of the next DF in a cascade of DFs for increased filter lengths. This signal is enabled by COENB low. |

## Pin Descriptions

| SYMBOL | PIN NUMBER | TYPE | NAME FUNCTION |
| :---: | :---: | :---: | :---: |
| COENB | 8 | 1 | A low on the $\overline{\text { COENB }}$ input enables the COUTO-7 and the TCCO output. A high on this input places all these outputs in their high impedance state. |
| DCMO-1 | 20-21 | 1 | These two inputs determine the use of the internal decimation registers as follows: <br> The coefficients pass from cell to cell at a rate determined by the number of decimation registers used. When no decimation registers are used, coefficients move from cell to cell on each clock. When one decimation register is used, coefficients move from cell to cell on every other clock, etc. These signals are latched and delayed by one clock internal to the DF. |
| SUMO-25 | $\begin{aligned} & 25,26, \\ & 28-51 \end{aligned}$ | 0 | These 26 three-state outputs are used to output the results of the internal filter cell computations. Individual filter cell results or the result of the shift-and-add output stage can be output. If an individual filter cell result is to be output, the ADRO-1 signals select the filter cell result. The SHADD signal determines whether the selected filter cell result or the output stage adder result is output. The signals $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ enable the most significant and least significant bits of the SUMO-25 result, respectively. Both SENBH and SENBL may be enabled simultaneously if the system has a 26 bit or larger bus. However, individual enables are provided to facilitate use with a 16 bit bus. |
| $\overline{\text { SENBH }}$ | 24 | 1 | A low on this input enables result bits SUM16-25. A high on this input places these bits in their high impedance state. |
| $\overline{\text { SENBL }}$ | 52 | 1 | A low on this input enables result bits SUMO-15. A high on this input places these bits on their high impedance state. |
| ADRO-1 | 22,23 | 1 | These two inputs select the one cell whose accumulator will be read through the output bus (SUMO-25) or added to the output stage accumulator. They also determine which accumulator will be cleared when ERASE is low. For selection of which accumulator to read through the output bus (SUMO-25) or which to add of the output stage accumulator, these inputs are latched in the DF and delayted by one clock internal to the device. If the ADRO-1 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADRO-1 selects the cell, will be output. This does not hinder normal operation since the ADRO-1 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock. |
| SHADD | 18 | 1 | The SHADD input controls the activation of the shift-and-add operation in the output stage. This signal is latched in the DF and delayed by one clock internal to the device. A detailed explanation is given in the DF Output Stage section. |
| $\overline{\text { RESET }}$ | 6 | 1 | A low on this input synchronously clears all the internal registers, except the cell accumulators. It can be used with ERASE to also clear all the accumulators simultaneously. This signal is latched in the DF and delayed by one clock internal to the DF. |
| $\overline{\text { ERASE }}$ | 7 | 1 | A low on this input synchronously clears the cell accumulator selected by the ADRO-1 signals. If $\overline{\operatorname{RESET}}$ is also low simultaneously, all cell accumulators are cleared. |

## Functional Description

The Digital Filter (DF) is composed of four filter cells cascaded together and an output stage for combining or selecting filter cell outputs (see Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 8 bit coefficient is multiplied by a 8 bit data sample, with the result added to the 26 bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

An 8 bit coefficient (CINO-7, TCCI) enters each cell through the $C$ register on the left and exits the cell on the right as signals COUTO-7 and TCCO. With no decimation, the coefficient moves directly from the C register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1,2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).
The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-7, TCCO) are connected to the CINO-7 and TCCI of the next cell to its right. The COENB input signal enables the COUTO-7 and TCCO outputs of the right-most cell to the COUTO-7 and TCCO pins of the DF.
The $C$ and $D$ registers are enabled for loading by CIENB. Loading is synchronous with CLK when CIENB is low. Note that CIEND is latched internally. it anables the iegister for loading after the next CLK following the onset of CIENB low. Actual loading occurs on the second CLK following the onset of CIENB low. Therefore, CIENB must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-7 inputs. In most basic FIR operations, CIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When CIENB is high, the coefficients are frozen.

These registers are cleared synchronously under control of RESET, which is latched and delayed exactly like CIENB.
The output of the $C$ register is one input of the multiplier.
The other input of the multiplier comes from the output of the X register. This register is loaded with a data sample from the DF input signals. DINO-7 and TCS discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when DIENB is low. Note that $\overline{\mathrm{DIENB}}$ is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Therefore, $\overline{\text { DIENB }}$ must be low during the clock cycle immediately preceding presentation of the sampie on the DINO-7 inputs. In most basic FIR operations, DIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the $X$ register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1. The multiplier output is sign extended and input as one operand of the 26 bit adder. The other adder operand is the output of the 26 bit accumulator. The adder output
is loaded synchronously into both the accumulator and the TREG.

The TREG loading is disabled by the cell select signal, Celln, where $n$ is the cell number. The cell select is decoded from the ADRO-1 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every other clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.
The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When RESET and ERASE are both low, the accumulator is cleared along with all other registers in the DF. Since both ERASE and $\overline{\text { RESET }}$ are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and RESET low.
The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, Celln, decoded from ADRO-1 and ERASE signal, Celln enable clearing of the accumulator on the next CLK.
The ERASE and $\overline{\text { RESET signals clear the DF internal regi- }}$ sters and states as follows:

| ERASE | RFSFT | CI FARING FFFECT |
| :---: | :---: | :--- |
| 1 | 1 | No clearing occurs, internal state <br> remains same. |
| 1 | 0 | $\overline{R E S E T}$ only active, all registers except <br> accumulators are cleared, including <br> the internal pipeline registers. |
| 0 | 1 | ERASE only active, the accumulator <br> whose address is given by the ADRO-1 <br> inputs is cleared. |
| 0 | 0 | Both $\overline{\text { RESET and } \overline{\text { ERASE }}}$accumulators as well as all other reg- <br> isters are cleared. |

## The DF Output Stage

The output stage consists of a 26 bit adder, 26 bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26 bit three-state driver stage (Figure 2).

The 26 bit output adder can add any filter cell accumulator result to the 18 most significant bits of the outupt buffer. This operation takes place in one clock period. The eight LSBs are lost. The filter cell accumulator is selected by the ADRO-1 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the 18 MSBs of the output buffer or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43481 FILTER CELL


FIGURE 2. HSP43481 OUTPUT STAGE

The $2 \hat{0}$ Least Significant Bits (LSESsj from either a ceii accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-1 or the output buffer is output to the bus. The mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-1. Otherwise the output mux selects the contents of the output buffer.

If the ADRO-1 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-1 selects the cell will be output. This does not hinder normal FIR operations since the ADRO-1
lines are changed sequentially. This feature facilitates the interface wtith slow memories where the output is required to be fixed for more than one clock.

The SUMO-25 output bus is controlled by the $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26 bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 9 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either unsigned or two's complement numbers. The TCS and TCCI input signals determine the type of arithmetic representation. Internally all values are represented by a 9 bit two's complement number. The value of the additional ninth bit depends on arithmentic representation selected. For two's complement arithmetic, the sign is extended into the ninth bit. For unsigned arithmetic, bit 9 is 0 .

The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum-of-products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. As a worst case assume the coefficients and data samples are always at their absolute maximum values.

Then the maximum numbers of temens in the sum pioducts are:

| NUMBER SYSTEM | MAX \# <br> OF TERMS |
| :--- | :---: |
| Two unsigned vectors | 1032 |
| Two two's complement vectors: |  |
| - Two positive vectors | 2080 |
| - Two negative vectors | 2047 |
| - One positive and one negative vector | 2064 |
| One unsigned and one two's complement |  |
| vector: |  |
| - Positive two's complement vector | 1036 |
| - Negative two's complement vector | 1028 |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple 30 MHz 4 tap filter example serves to illustrate more clearly the operation of the DF. Table 1 shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn, enters the DF from the top, with each cell receiving the same sample simultaneously. Each cell
accumulates the sum-of-products for one output point. Four sums-of-products are calculated simultaneously, but staggered in time so that a new output is available every system clock.
Detailed operation of the DF to perform a basic 4 tap, 8 bit coefficient, 8 bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram

TABLE 1. 25MHz, 4 TAP FIR FILTER SEQUENCE


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $C_{3} \times X_{0}$ | 0 | 0 | 0 | - |
| 1 | $+C_{2} \times X_{1}$ | $C_{3} \times X_{1}$ | 0 | 0 | - |
| 2 | $+C_{1} \times X_{2}$ | $+C_{2} \times X_{2}$ | $C_{3} \times X_{2}$ | 0 | - |
| 3 | $+C_{0} \times X_{3}$ | $+C_{1} \times X_{3}$ | $+C_{2} \times X_{3}$ | $C_{3} \times X_{3}$ | Cell $0\left(Y_{3}\right)$ |
| 4 | $C_{3} \times X_{4}$ | $+C_{0} \times X_{4}$ | $+C_{1} \times X_{4}$ | $+C_{2} \times X_{4}$ | Cell $1\left(Y_{4}\right)$ |
| 5 | $+C_{2} \times X_{5}$ | $C_{3} \times X_{5}$ | $+C_{0} \times X_{5}$ | $+C_{1} \times X_{5}$ | Cell 2 $\left(Y_{5}\right)$ |
| 6 | $+C_{1} \times X_{6}$ | $+C_{2} \times X_{6}$ | $C_{3} \times X_{6}$ | $+C_{0} \times X_{6}$ | Cell 3 $\left(Y_{6}\right)$ |
| 7 | $+C_{0} \times X_{7}$ | $+C_{1} \times X_{7}$ | $+C_{2} \times X_{7}$ | $C_{3} \times X_{7}$ | Cell 0 $\left(Y_{7}\right)$ |



FIGURE 3. $30 \mathrm{MHz}, 4$ TAP FIR FILTER APPLICATION SCHEMATIC
(Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore, the delay from presentation of data and coefficients at the DINO-7 and CINO-7 inputs to a sum appearing at the SUMO-25 output is:
$k+7 d$ where
$k=$ filter length
$T d=4$, the internal pipeline delay of DF


FIGURE 4. 30 MHz 4 TAP FILTER TIMING


FIGURE 5. 3OMHz 8 TAP FILTER USING TWO CASCADED HSP43481s

## Extended FIR Filter Length

Filter lengths greater than four taps can be created by either cascading together multiple DFs or "reusing" a single DF. Using multiple devices, an FIR filter of over 1024 taps can be constructed to operate at a 30 MHz sample rate. Using a single DF clocked at 30 MHz , an FIR filter of over 1024 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.

## Cascade Configuration

To design a filter length $L>4$, L/4 DFs are cascaded by connecting the COUTO-7 outputs of the (i)th DF to the CINO-7 inputs of the $(i+1)$ th DF. The DINO-7 inputs and SUMO-25 outputs of all the DFs are slso tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 4 tap FIR, except the ERASE and SENBL/SENBH signals must be enabled independently of the two DFs in order to clear the correct accumulators and enable the SUMO-25 output signals at the proper times.

## Single DF Configuration

Using a DF, a filter of length $L>4$ can be constructed by processing in $\mathrm{L} / 4$ passes as illustrated in Table 2 for an 8 tap FIR. Each pass is composed of $T p=7+L$ cycles and computes four output samples. In pass $i$, the samples with indices $i \times 4$ to $i \times 4+(L+2)$ enter the DINO-7 inputs. The coefficients $\mathrm{C}_{0}-\mathrm{C}_{\mathrm{L}-1}$ enter the CINO-7 inputs, followed by three zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filling of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient And Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $8 \times 8$ and combine these partial products by shifting and adding to obtain the final result. The shifting and adding can be accomplished with external adders (for full speed) or with the DFs shift-and-add mechanism contained in its output stage (at reduced speed).

TABLE 2. 8 TAP FIR FILTER SEQUENCE USING SINGLE DF


| CLK | cello | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | $\mathrm{C}_{7} \times \mathrm{X}_{1}$ | 0 | 0 | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{X}_{2}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{3}$ | $\mathrm{C}_{7} \times{ }^{3}$ | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{4}$ | - |
| 5 | $+\mathrm{C}_{2} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{5}$ | - |
| 6 | $+\mathrm{C}_{1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{6}$ | $+C_{4} \times{ }^{6}$ | - |
| 7 | $+\mathrm{C}_{0} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{7}$ | $+c_{3} \times \times_{7}$ | Cell $0\left(\mathrm{~N}_{7}\right)$ |
| 8 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{8}$ | $+C_{1} \times x_{8}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | Cell $1\left(\gamma_{8}\right)$ |
| 9 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{9}$ | Cell $2\left(\mathrm{Y}_{9}\right)$ |
| 10 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{10}$ | Cell $3\left(Y_{10}\right)$ |
| 11 | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | - |
| 12 | $+\mathrm{C}_{6} \times \mathrm{X}_{5}$ | $\mathrm{C}_{7} \times \mathrm{X}_{5}$ | 0 | 0 | - |
| 13 | $+\mathrm{C}_{5} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{6}$ | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ | 0 | - |
| 14 | $+C_{4} \times \mathrm{X}_{7}$ | $+C_{5} \times{ }^{4}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | - |
| 15 | $+\mathrm{C}_{3} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{8}$ | - |
| 16 | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{9}$ | - |
| 17 | $+\mathrm{C}_{1} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{10}$ | - |
| 18 | $+\mathrm{C}_{0} \times \mathrm{X}_{11}$ | $+C_{1} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{11}$ | Cell $0\left(Y_{11}\right)$ |
| 19 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell $1\left(Y_{12}\right)$ |
| 20 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{13}$ | Cell $2\left(Y_{13}\right)$ |
| 21 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{14}$ | Cell $3\left(Y_{14}\right)$ |



FIGURE 6. 30 MHz 8 TAP FIR FILTER TIMING

## Decimation/Resampling

The HSP43481 provides a mechanism for decimating by factors of 2, 3 or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient pass through the cell. These allow the coefficients to be delayed by 1, 2 or 3 clocks through the cell. The
sequence table (Table 3) for a decimate-by-two filter illustrates the technique.
Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 8 tap FIR filter, including pipelining, is shown in Figure 7.

TABLE 3. 8 TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE, 30 MHz IN, 15 MHz OUT


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 |  |  | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | 0 |  |  | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{X}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ |  |  | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{3}$ |  |  | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ |  | - |
| 5 | $+\mathrm{C}_{2} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{5}$ |  | - |
| 6 | $+C_{1} \times x_{6}$ | $+C_{3} \times X_{6}$ | $+C_{5} \times{ }^{6}$ | $+C_{7} \times \mathrm{X}_{6}$ | - |
| 7 | $+\mathrm{C}_{0} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{7}$ | Cello (Y7) |
| 8 | $\mathrm{C}_{7} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{8}$ | Cello ( $\mathrm{Y}_{7}$ ) |
| 9 | $+C_{6} \times{ }^{1} 9$ | $+C_{0} \times{ }_{9}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{9}$ | Cell $1\left(\mathrm{Y}_{9}\right)$ |
| 10 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ | $\mathrm{C}_{7} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{10}$ | Cell $1\left(Y_{9}\right)$ |
| 11 | $+\mathrm{C}_{4} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{11}$ | $+C_{0} \times{ }_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | Cell $2\left(Y_{11}\right)$ |
| 12 | $+\mathrm{C}_{3} \times \mathrm{X}_{12}$ | $+C_{5} \times \mathrm{X}_{12}$ | $\mathrm{C}_{7} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{12}$ | Cell $2\left(Y_{11}\right)$ |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{13}$ | $+C_{0} \times X_{13}$ | Cell $3\left(Y_{13}\right)$ |
| 14 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ | $+C_{3} \times{ }_{14}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{14}$ | $\mathrm{C}_{7 \times 1} \times 14$ | Cell $3\left(Y_{13}\right)$ |
| 15 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{15}$ | Cell $0\left(Y_{15}\right)$ |

CLK
 RESET $\longrightarrow$ ERASE 7.
dino-7 $\quad\left|x_{0}\right| x_{1}\left|x_{2}\right| x_{3}\left|x_{4}\right| x_{5}\left|x_{6}\right| x_{7} \mid \cdots$
$\overline{\text { DIENB }}$ 7717.

CINO-7

$$
\left|c_{7}\right| c_{6}\left|c_{5}\right| c_{4}\left|c_{3}\right| c_{2}\left|c_{1}\right| c_{0} \mid \ldots
$$

CIENB
TZIT
adRO-1


FIGURE 7. 8 TAP DECIMATE-BY-TWO FIR FILTER TIMING, 30 MHz IN, 15 MHz OUT

## Absolute Maximum Ratings




```
Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -650
ESD
                            .Class }
Maximum Package Power Dissipation at }7\mp@subsup{0}{}{\circ}\textrm{C
1.9W (PLCC), 2.6W (PGA)
0jc
*)
```



```
Gate Count
9371
Junction Temperature
150}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PLCC), 175}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PGA)
Lead Temperature (Soldering 10s)
    300%
CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating
and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
```


## Operating Conditions

```
Operating Voltage Range
5V \pm5%
Operating Temperature Ranges
\(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 110 | mA | $v_{C C}=M a x$ <br> CLK Freauency 20MHz <br> Note 1, Note 3 |
| ${ }^{\text {I Coss }}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Note 3 |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{C C}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=$ Max |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{1 \mathrm{HC}}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| VILC | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{Cl}_{\text {IN }}$ | Input Capacitance $\begin{array}{r}\text { PLCC } \\ \\ \text { PGA }\end{array}$ | - | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency 1 MHz All Measurements |
| COUT | Output Capacitance $\begin{array}{rr}\text { PLCC } \\ & \text { PGA }\end{array}$ | - | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | Referenced to GND $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \text { Note } 2$ |

NOTES: 1. Operating supply current is proportional to frequency. Typical rating is $5.5 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Oufput load per test circuit and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | -30 (30MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| TCP | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| TCL | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| TIH | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 26 | - | 22 | - | 19 | ns |  |
| Toed | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| TODS | CLK to SUM Output Delay | - | 30 | - | 26 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | - | 6 | - | 6 | ns | Note 1 |
| Tof | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE: 1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Waveforms



CLOCK AC PARAMETERS


* Input includes: DINO-7, CINO-7, DIENB, CIENB, ERASE, RESET, DCMO-1, ADRO-1, TCS, TCCI, SHADD

INPUT SETUP AND HOLD


RISE AND FALL TIMES

A.C. Testing: Inputs are driven at 3.0 V for a Logic " 1 " and 0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and 0.0 V and measured at 2.0 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $\mathbf{O M H z}$ to $\mathbf{2 5 . 6 \mathrm { MHz } \text { Sample Rate }}$
- Four Filter Cells
- 8-Bit Coefficients and Signal Data
- Low Power CMOS Operation
- $I_{\text {ccsB }}=500 \mu \mathrm{~A}$ Maximum
- $I_{\text {CCOP }}=110 \mu \mathrm{~A}$ Maximum at 20 MHz
- 26-Bit Accumulator Per Stage
- Filter Lengths Up To 1032 Taps
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP43481GM-20/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP43481GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The HSP43481/883 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of four filter cells cascaded internally and a shitt-and- add output stage, all in a single integrated circuit. Each filter cell contains an $8 \times 8$ multiplier, three decimation registers and a 26 -bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by eight-bits. The HSP43481/883 has a maximum sample rate of 25.6 MHz . The effective multiply-accumulate (MAC) rate is 102 MHz .

The HSP43481/883 can be configured to process expanded coefficient and word sizes. Multiple devices can be cascaded for larger filter lengths without degrading the sample rate or a single device can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The HSP43481/883 provides for unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as $\mathrm{N} \times \mathrm{N}$ spatial correlations/convolutions for image processing applications.

## Block Diagram



## Absolute Maximum Ratings

Supply Voltage . ................................................. +8.0 V
Input, Output Voltage Applied ........... GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$

Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering, Ten Seconds) $\ldots . . . . . . .$.
ESD Classification
Class 1
CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP43481/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{l} \mathrm{OH}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { (Note } 1 \text { ) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{V}_{\text {OL }}$ | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{VO}-4.5 \mathrm{v} \text { (Nete } 1 \text { ) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T^{\prime} \mathrm{A} \leq+125{ }^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{O U T}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $-10$ | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & v_{\mathrm{CC}}=5.5 \mathrm{~V}(\text { Note } 2) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 110.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | - |  |

NOTES: 1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5.5 \mathrm{~mA} / \mathrm{MHz}$.

## Reliability Information

| Thermal Resistance | $\theta_{j a}$ | $\theta_{\mathrm{jc}}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $38.44{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $9.92{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package |  | 1.30 Watt |
| Gate Count |  | 9370 Gates |

TABLE 2. HSP43481/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBEL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | TCP | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | $\mathrm{T}_{\mathrm{CL}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | ${ }^{\text {T }}$ CH | Note 1 | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | TIS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | $\mathrm{TIH}^{\text {H }}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | ToED | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .

TABLE 3. HSP43481/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cl}_{\text {IN }}$ | $\mathrm{V}_{\mathrm{CC}}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$ All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | cout |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | ToF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES: 1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $C_{L}=40 p F$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \&D | Samples/5005 | $1,7,9$ |

HSP43481/883

Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | RIJRN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | 민Nㄴ-! SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PA: NAME | Duran tix SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { Put } \\ \text { NAME } \end{gathered}$ | Dưhîi-ivi SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| K1 | TCCO | $\mathrm{v}_{\mathrm{CO} / 2}$ | C2 | CIENB | F10 | B6 | SUMO | $\mathrm{v}_{\mathrm{CC} / 2}$ | H10 | SUM19 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| J1 | ERASE | F10 | 82 | CIN6 | F6 | A6 | SENBL | F10 | G10 | SUM17 | $\mathrm{V}_{\mathrm{Cc} / 2}$ |
| H1 | RESET | F11 | A2 | CIN7 | F7 | L7 | CLK | FO | F10 | SUM15 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| G1 | TCs | F7 | L3 | COUT5 | $\mathrm{v}_{\mathrm{cc} / 2}$ | K7 | DCM1 | F6 | E10 | $V_{\text {SS }}$ | GND |
| F1 | DIN5 | F5 | K3 | COUT6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B7 | SUM2 | $\mathrm{v}_{\mathrm{CC} / 2}$ | D10 | SUM12 | $V_{C C} / 2$ |
| E1 | DIN3 | F3 | B3 | CIN4 | F4 | A7 | SUM1 | $\mathrm{V}_{\mathrm{cc} / 2}$ | C10 | SUM10 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| D1 | DIN1 | F1 | A3 | CIN5 | F5 | L8 | ADDR1 | F1 | B10 | SUM8 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| C1 | DINO | FO | L4 | COUT3 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K8 | DCM0 | F5 | A10 | SUM7 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| B1 | TCCI | F8 | K4 | COUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B8 | SUM4 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K11 | SUM23 | $\mathrm{v}_{\mathrm{cc}} / 2$ |
| L2 | COUT7 | $\mathrm{v}_{\mathrm{CC} / 2}$ | B4 | CIN2 | F2 | A8 | SUM3 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J11 | SUM22 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| K2 | COENB | F10 | A4 | CIN3 | F3 | L9 | ADDRO | FO | H11 | SUM20 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| J2 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | L5 | COUT1 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K9 | SENBH | F10 | G11 | SUM18 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| H2 | DIENB | F10 | K5 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B9 | SUM6 | $\mathrm{V}_{\mathrm{Cc} / 2}$ | F11 | SUM16 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| G2 | DIN7 | F8 | B5 | CINO | FO | A9 | SUM5 | $\mathrm{v}_{\mathrm{CC} / 2}$ | E11 | SUM14 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| F2 | DIN6 | F6 | A5 | CIN1 | F1 | L10 | SUM25 | $\mathrm{v}_{\mathrm{CC} / 2}$ | 011 | SUM13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| E2 | DIN4 | F4 | L6 | COUTO | $\mathrm{v}_{\mathrm{CC} / 2}$ | K10 | SUM24 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C11 | SUM11 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| D2 | DIN2 | F2 | K6 | SHADD | F9 | J10 | SUM21 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B11 | SUM9 | $\mathrm{v}_{\mathrm{CC} / 2}$ |

NOTES: 1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega \mathbf{(} \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $F 0=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2$,

40\% - 60\% Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \max ., \mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Metallization Topology

DIE DIMENSIONS:
$253 \times 230 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY:
$1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HSP43481/883


Digital Filter

## Features

- Eight Filter Cells
- 0 to $\mathbf{3 0 M H z}$ Sample Rate
- 8-Bit Coefficients and Signal Data
- 26-Bit Accumulator Per Stage
- Filter Lengths Over 1000 Taps
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP43881JC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43881JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43881JC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43881GC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43881GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43881GC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The HSP43881 is a video speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $8 \times 8$-bit multiplier, three decimation registers and a 26 -bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8-bits. The HSP43881 has a maximum sample rate of 30 MHz . The effective multiply accumulate (mac) rate is 240 MHz .

The HSP43881 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8 -bit unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and NxN spatial correlations/convolutions for image processing applications.

## Block Diagram




## Pin Description

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | A3, A10, B1, <br> D11, F10, J1, K4, L7 |  | +5V Power Supply Input |
| $\mathrm{V}_{\mathrm{SS}}$ | $\begin{gathered} \text { A1, A11, E2, F1, } \\ \text { E11, H11, K3, } \\ \text { K6, L9 } \end{gathered}$ |  | Power Supply Ground Input |
| CLK | G3 | I | The CLK input provides the DF system sample clock. The maximum clock frequency is is 30 MHz . |
| DINO-7 | $\begin{gathered} \text { A5-8, B6-7, } \\ \text { C6-7 } \end{gathered}$ | 1 | These eight inputs are the data sample input bus. Eight bit data samples are synchronously loaded through these pins to the $X$ register of each filter cell simultaneously. <br> The DIENB signal enables loading, which is synchronous on the rising edge of the clock signal. |
| TCS | B5 | 1 | The TCS input determines the number system interpretation of the data input samples on pins DINO-7 as follows: <br> TCS $=$ Low $\rightarrow$ Unsigned Arithmetic <br> TCS $=$ High $\rightarrow$ Two's Complement Arithmetic <br> The TCS signal is synchronously loaded into the X register in the same way as the DINO-7 inputs. |
| $\overline{\text { DIENB }}$ | C5 | 1 | A low on this enables the data sample input bus (DINO-7) to all the filter cells. A rising edge of the CLK signal occurring while DIENB is low will load the $X$ register of every filter cell with the 8 bit value present on DINO-7. A high on this input forces all the bits of the data sample input bus to zero; a rising CLK edge when DIENB is high will load the X register of every filter cell with all zeros. This signal is latched inside the DF, delaying its effect by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired data on the n!no-7 inpute. Deta!led operation is shoun! in !eter timing diagrame. |
| CINO-7 | $\begin{gathered} \text { B9-11, C10-11, } \\ \text { D10, E9-10 } \end{gathered}$ | 1 | These eight inputs are used to input the 8 bit coefficients. The coefficients are synchronously synchronously loaded into the C register of filter CELLL 0 if a rising edge of CLK occurs while $\overline{\mathrm{CIENB}}$ is low. The CIENB signal is delayed by one clock as discussed beiow. |
| TCCI | A9 | I | The TCCI input determines the number system interpretation of the coefficient inputs on pins CINO-7 as follows: <br> TCCI $=$ LOW $\rightarrow$ Unsigned Arithmetic <br> TCCI $=\mathrm{HIGH} \rightarrow$ Two's Complement Arithmetic <br> The TCCI signal is synchronously loaded into the C register in the same way as the CINO-7 inputs. |
| $\overline{\text { CIENB }}$ | B8 | I | A low on this input enable the $C$ register of every filter cell and the D registers (decimation) of every filter cell according to the state of the DCMO-1 inputs. A rising edge of the CLK signal occurring while CIENB is low will load the C register and appropriate D registers with the coefficient data present at their inputs. This privides the mechanism for shifting the coefficients from cell to cell through the device. A high on this input freezes the contents of the C register and the D registers, ignoring the CLK signal. This signal is latched and delayed by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired coefficient on the CINO-7 inputs. Detailed operation is shown in the Timing Diagrams section. |
| COUTO-7 | $\begin{gathered} B 2, C_{1}-2, D_{1}-2 \\ E_{1}, E_{3}, F_{2} \end{gathered}$ | 0 | These eight three-state outputs are used to output the 8 bit coefficients from filter cell 7. These outputs are enabled by the COENB signal low. These outputs may be tied to the CINO-7 inputs of the same DF to recirculate the coefficients, or they may be tied to the CINO-7 inputs of another DF to cascade DFs for longer filter lengths. |
| TCCO | B3 | 0 | The TCCO three-state output determines the number system representation of the coefficients output on COUTO-7. It tracks the TCCI signal to this same DF. It should be tied to the TCCI input of the next DF in a cascade of DFs for increased filter lengths. This signal is enabled by COENB low. |
| COENB | A2 | 1 | A low on the $\overline{\operatorname{COENB}}$ input enables the COUTO-7 and the TCCO output. A high on this input places all these outputs in their high impedance state. |

## Pin Description (Continued)

| SYMBOL | PIN NUMBER | TYPE | NAME FUNCTION |
| :---: | :---: | :---: | :---: |
| DCMO-1 | G2, L1 | 1 | These two inputs determine the use of the internal decimation registers as follows: <br> The coefficients pass from cell to cell at a rate determined by the number of decimation registers used. When no decimation registers are used, coefficients move from cell to cell on each clock. When one decimation register is used, coefficients move from cell to cell on every other clock, etc. These signals are latched and delayed by one clock internal to the DF. |
| SUMO-25 | $\begin{gathered} \mathrm{J} 2, \mathrm{~J} 5-8, \\ \mathrm{~J} 10, \mathrm{~K} 2, \\ \mathrm{~K} 5-11, \\ \mathrm{~L} 2-6, \mathrm{~L} 8, \\ \mathrm{~L} 10-11 \end{gathered}$ | 0 | These 26 three-state outputs are used to output the results of the internal filter cell computations. Individual filter cell results or the result of the shift-and-add output stage can be output. If an individual filter cell result is to be output, the ADRO-2 signals select the filter cell result. The SHADD signal determines whether the selected filter cell result or the output stage adder result is output. The signals $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ enable the most significant and least significant bits of the SUMO-25 result, respectively. Both SENBH and SENBL may be enabled simultaneously if the system has a 26 bit or larger bus. However, individual enables are provided to facilitate use with a 16 bit bus. |
| $\widehat{\text { SENBH }}$ | K1 | I | A low on this input enables result bits SUM16-25. A high on this input places these bits in their high impedance state. |
| SENBL | E11 | 1 | A low on this input enables result bits SUMO-15. A high on this input places these bits in their high impedance state. |
| - ADRO-2 | G1, H1-2 | 1 | These inputs select the one cell whose accumulator will be read through the output bus (SUMO-25) or added to the output stage accumulator. They also determine which accumulator will be cleared when ERASE is low. For selection of which accumulator to read through the output bus (SUMO-25) or which to add of the output stage accumulator, these inputs are latched in the DF and delayed by one clock internal to the device. If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADRO-1 selects the cell, will be output. This does not hinder normal operation since the ADR0-1 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock. |
| SHADD | F3 | 1 | The SHADD input controls the activation of the shift-and-add operation in the output stage. This signal is latched in the DF and delayed by one clock internal to the device. A detailed explanation is given in the DF Output Stage section. |
| RESET | A4 | 1 | A low on this input synchronously clears all the internal registers, except the cell accumulators. It can be used with ERASE to also clear all the accumulators simultaneously. This signal is latched in the DF and delayed by one clock internal to the DF. |
| ERASE | B4 | 1 | A low on this input synchronously clears the cell accumulator selected by the ADRO-1 signals. If RESET is also low simultaneously, all cell accumulators are cleared. |
| ALIGN PIN | C3 |  | Used for aligning chip in socket or printed circuit board. Must be left as a no connect in circuit. |

## Functional Description

The Digital Filter Processor (DF) is composed of eight filter cells cascaded together and an output stage for combining or selecting filter cell outputs (See Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 8-bit coefficient is multiplied by a 8 - bit data sample, with the result added to the 26 -bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

A 8-bit coefficient (CINO-7) enters each cell through the C register on the left and exits the cell on the right as signals COUTO-7. With no decimation, the coefficient moves directly from the C register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1,2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).

The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-7) are connected to the CINO-7 inputs of the next cell to its right. The COENB input signal enables the COUTO-7 outputs of the right most cell to the COUTO-7 pins of the device.

The $C$ and $D$ registers are enabled for loading by CIENB. Loading is synchronous with CLK when CIENB is low. Note that CIENB is latched internally. It enables the register for
 Actual loading occurs on the second CLK following the onset of $\overline{C I E N B}$ low. Therefore $\overline{C I E N B}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-7 inputs. In most basic FIR operations, CIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When CIENB is high, the coefficients are frozen.

These registers are cleared synchronously under control of $\overline{R E S E T}$, which is latched and delayed exactly like $\overline{\text { CIENB. }}$
The output of the C register ( $\mathrm{CO}-8$ ) is one input to $8 \times 8$ multiplier.

The other input to the $8 \times 8$ multiplier comes from the output of the $X$ register. This register is loaded with a data sample from the device input signals DINO-7 discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when DIENB is low. Note that $\overline{D I E N B}$ is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Actual loading occurs on the second CLK following the onset of $\overline{\text { IIENB }}$ low; therefore, $\overline{\text { DIENB }}$ must be low during the clock cycle immediately preceding presentation of the data sample on the DINO-7 inputs. In most basic FIR operations, DIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the $X$ register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1 (Figure 1). The multiplier output is sign extended and input as one operand of the 26 -bit adder. The other
adder operand is the output of the 26-bit accumulator. The adder output is loaded synchronously into both the accumulator and the TREG.
The TREG loading is disabled by the cell select signal, CELLn, where $n$ is the cell number. The cell select is decoded from the ADRO-2 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.
The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When RESET and ERASE are both low, the accumulator is cleared along with all other registers on the device. Since $\overline{E R A S E}$ and $\overline{R E S E T}$ are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and RESET low.
The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, CELLn, decoded from ADRO-2 and the ERASE signal enable clearing of the accumulator on the next CLK.
The ERASE and RESET signals clear the DF internal registers and states as follows:

| ERASE | RESET | CLEARING EFFECT |
| :---: | :---: | :---: |
| 1 | 1 | No clearing occurs, internal state remains same |
| 1 | 0 | $\overline{R E S E T}$ only active, all registers except accumulators are cleared, including the internal pipeline registers. |
| 0 | 1 | ERASE only active, the accumulator whose address is given by the ADRO-2 inputs is cleared. |
| 0 | 0 | Both $\overline{\text { RESET }}$ and $\overline{\text { ERASE }}$ active, all accumulators as well as all other registers are cleared. |

## The DF Output Stage

The output stage consists of a 26-bit adder, 26-bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26-bit three-state driver stage (Figure 2).
The 26-bit output adder can add any filter cell accumulator result to the 18 most significant bits of the output buffer. This result is stored back in the output buffer. This operation takes place in one clock period. The eight LSBs of the output buffer are lost. The filter cell accumulator is selected by the ADRO-2 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the output buffer 18 MSBs or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. The SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43881 FILTER CELL


FIGURE 2. HSP43881 DF OUTPUT STAGE

The 26 least significant bits (LSBs) from either a cell accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-2 or the output buffer is output to the bus. This mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-2. Otherwise the output mux selects the contents of the output buffer.
If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent' accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-2 selects the cell will be output. This does not hinder normal FIR operation since the ADRO-2 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock.

The SUMO-25 output bus is controlled by the SENBH and SENBL signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26-bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 10 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either unsigned or two's complement numbers. The TCS and TCCl inputs determine the type of arithmetic representation. Internally all values are represented by a 9-bit two's complement number. The value of the additional ninth bit depends on the arithmetic representation selected. For two's complement arithmetic, the sign is extended into the ninth bit. For unsigned arithmetic, bit 9 is 0.
The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum of products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. Then maximum numbers of terms in the sum products are:

| NUMBER SYSTEM | MAX \# <br> OF TERMS |
| :--- | :---: |
| Two unsigned vectors | 1032 |
| Two two's complement: |  |
| - Two positive vectors | 2080 |
| - Negative vectors |  |
| - One positive and one negative vector | 2047 |
| One unsigned and one two's complement <br> vector: <br> - Positive two's complement vector <br> - Negative two's complement vector |  |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple, 30 MHz 8 -tap filter example serves to illustrate more clearly the operation of the DF. The sequence table (Table 1) shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn , enters the DF from the top, with each cell receiving the same sample simultaneously. Each cell accumulates the sum of products for one output point. Eight sums of products are calculated simultaneously, but staggered in time so that a new output is available every system clock.

## TABLE 1. HSP43881 30MHz, 8 TAP FIR FILTER SEQUENCE

| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 |  |  |  |  | - |
| 1 | $+C_{6} \times x_{1}$ | $\mathrm{C}_{7} \times \mathrm{X}_{1}$ | 0 | 0 |  |  |  |  | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{X}_{2}$ | $+c_{6} \times x_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 |  |  |  |  | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+C_{5} \times x_{3}$ | $+C_{6} \times x_{3}$ | $\mathrm{C}_{7} \times \mathrm{X}_{3}$ |  |  |  |  | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{X}_{4}$ | $+C_{4} \times \mathrm{X}_{4}$ | $+C_{5} \times{ }^{4}$ | $+C_{6} \times x_{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ |  |  |  | - |
| 5 | $+C_{2} \times{ }^{5}$ | $\mathrm{C}_{3} \times \mathrm{X}_{5}$ | $+C_{4} \times{ }_{5}$ | $+C_{5} \times{ }_{5}$ | $+C_{6} \times{ }_{5}$ | $\mathrm{C}_{7} \times{ }^{\text {x }}$ |  |  | - |
| 6 | $+\mathrm{C}_{1} \times \mathrm{X}_{6}$ | $+C_{2} \times \mathrm{X}_{6}$ | $+C_{3} \times x_{6}$ | $+C_{4} \times x_{6}$ | $+C_{5} \times{ }^{6}$ | $+C_{6} \times x_{6}$ | $C_{7} \times{ }^{1} 6$ |  | - |
| 7 | $+C_{0} \times x_{7}$ | $+c_{1} \times x_{7}$ | $+C_{2} \times{ }^{+}$ | $+C_{3} \times{ }^{4}$ | $+C_{4} \times{ }^{4}$ | $+C_{5} \times{ }^{1}$ | $+C_{6} \times x_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | Cell 0 (Y7) |
| 8 | $\mathrm{C}_{7} \times{ }_{8}$ | $+C_{0} \times{ }_{8}$ | $+C_{1} \times{ }_{8}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | $+C_{3} \times x_{8}$ | $+C_{4} \times x_{8}$ | $+C_{5} \times{ }_{8}$ | $+C_{6} \times x_{8}$ | Cell 1 (Y8) |
| 9 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ | $\mathrm{C}_{7} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{9}$ | $+C_{1} \times{ }^{2}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+C_{3} \times x_{9}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{9}$ | $+C_{5} \times{ }^{1}$ | Cell 2 (Y9) |
| 10 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ | $+C_{6} \times{ }_{10}$ | $\mathrm{C}_{7} \times \mathrm{X}_{10}$ | $+c_{0} \times{ }_{10}$ | $+c_{1} \times{ }_{10}$ | $+c_{2} \times{ }_{10}$ | $+C_{3} \times{ }_{10}$ | $+C_{4} \times{ }_{10}$ | Cell 3 (Y10) |
| 11 | $+C_{4} \times{ }^{111}$ | $+C_{5} \times x_{11}$ | $+C_{6} \times 11$ | $\mathrm{C}_{7} \times \mathrm{X}_{11}$ | $+C_{0 \times 11}$ | $+c_{1} \times{ }_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+C_{3} \times x_{11}$ | Cell 4 (Y11) |
| 12 | $+C_{3} \times{ }_{12}$ | $+C_{4} \times{ }_{12}$ | $+C_{5} \times{ }_{12}$ | $+C_{6} \times x_{12}$ | $C_{7} \times{ }_{12}$ | $+c_{0} \times{ }_{12}$ | $+c_{1} \times{ }_{12}$ | $+C_{2} \times{ }_{12}$ | Cell 5 (Y12) |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+c_{3} \times x_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+C_{5} \times{ }_{13}$ | $+C_{6} \times{ }_{13}$ | $\mathrm{C}_{7} \times \mathrm{X}_{13}$ | $+C_{0} \times{ }_{13}$ | $+c_{1} \times{ }_{13}$ | Cell 6 (Y13) |
| 14 | $+C_{1} \times{ }_{14}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{14}$ | $+C_{3} \times{ }_{14}$ | $+C_{4} \times{ }_{14}$ | $+C_{5} \times{ }_{14}$ | $+C_{6} \times{ }_{14}$ | $+C_{7} \times{ }_{14}$ | $+C_{0} \times x_{14}$ | Cell 7 (Y14) |
| 15 | $+\mathrm{C}_{0} \times{ }_{15}$ | $+C_{1} \times{ }_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+C_{3} \times{ }_{15}$ | $+C_{4} \times{ }_{15}$ | $+C_{5} \times{ }_{15}$ | $+C_{6} \times{ }_{15}$ | $\mathrm{C}_{7} \times{ }^{15}$ | Cell 0 (Y15) |



FIGURE 3. HSP43881 30MHz, 8 TAP FIR FILTER APPLICATION SCHEMATIC

Detailed operation of the DF to perform a basic 8-tap, 8-bit coefficient, 8-bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram (Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore the delay from presentation of data and coefficients at the DINO-7 and CINO-7 inputs to a sum appearing at the SUMO-25 output is:
$k+T d$
where
$k=$ filter length
$T d=4$, the internal pipeline delay of DF
After the pipeline has filled, a new output sample is available every clock. The delay to last sample output from last sample input is Td.

The output sums, Yn , shown in the timing diagram are derived from the sum-of-products equation:
$Y(n)=C(0) \times X(n)+C(1) \times X(n-1)+C(2) \times X(n-2)+C(3)$ $x X(n-3)+C(4) \times X(n-4)+C(5) \times X(n-5)+C(6) \times X(n-6)$ $+C(7) \times X(n-7)$

## Extended FIR Filter Length

Filter lengths greater that eight taps can be created by either cascading together multiple DF devices or "reusing" a single device. Using multiple devices, an FIR filter of over 1000 taps can be constructed to operate at a 30 MHz sample rate. Using a single device clocked at 30 MHz , an FIR filter of over 1000 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.


FIGURE 4. HSP43881 30MHz, 8 TAP FIR FILTER TIMING


FIGURE 5. HSP43881 $30 \mathrm{MHz}, 16$ TAP FIR FILTER CASCADE APPLICATION SCHEMATIC.

## Cascade Configuration

To design a filter length L>8, L/8 DFs are cascaded by connecting the COUTO-7 outputs of the (i)th DF to the CINO-7 inputs of the (i+1)th DF. The DINO-7 inputs and SUM0-25 outputs of all the DFs are also tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 8-tap FIR, except the ERASE and SENBL/SENBH
signals must be enabled independently for the two DFs in order to clear the correct accumulators and enable the SUM0-25 output signals at the proper times.

## Single DF Configuration

Using a single DF, a filter of length L>8 can be constructed by processing in $\mathrm{L} / 8$ passes as illustrated in the following table (Table 2) for a 16-tap FIR. Each pass is composed of

TABLE 2. HSP43881 16-TAP FIR FILTER SEQUENCE USING A SINGLE DF


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 |  |  |  |  | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | $\mathrm{C}_{15} \times \mathrm{X}_{1}$ | 0 | 0 |  |  |  |  | - |
| 8 | $+C_{13} \times{ }^{2}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 |  |  |  |  | - |
| 9 | $+\mathrm{C}_{12} \times \mathrm{X}_{3}$ |  |  | $\mathrm{C}_{15 \times} \times{ }^{\text {a }}$ |  |  |  |  | - |
| 10 | $+\mathrm{C}_{11} \times \mathrm{X}_{4}$ |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ |  |  |  | - |
| 11 | $+\mathrm{C}_{10} \times \mathrm{X}_{5}$ |  |  | $+C_{13} \times{ }_{5}$ |  | $c_{15} \times{ }_{5}$ |  |  | - |
| 12 | $+\mathrm{C}_{9} \times \mathrm{X}_{6}$ |  |  | $+\mathrm{C}_{12} \times \mathrm{x}_{6}$ |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{6}$ |  | - |
| 13 | $+\mathrm{C}_{8} \times \mathrm{x}_{7}$ |  |  | $+C_{11} \times x_{7}$ |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{7}$ | - |
| 14 | $+C_{7} \times{ }_{8}$ |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{8}$ |  |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{8}$ | - |
| 15 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ |  |  | $+\mathrm{C}_{9} \times{ }^{\prime}$ |  |  |  | $+\mathrm{C}_{13} \times \times_{9}$ | - |
| 16 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ |  |  | $+C_{8} \times 10$ |  |  |  | $+C_{12} \times \mathrm{X}_{10}$ | - |
| 17 | $+C_{4} \times \mathrm{X}_{11}$ |  |  | $+C_{7} \times{ }^{11}$ |  |  |  | $+C_{11} \times \mathrm{X}_{11}$ | - |
| 18 | $+C_{3} \times X_{12}$ |  |  | $+C_{6} \times \times 12$ |  |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{12}$ | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ |  |  | $+C_{5} \times{ }^{13}$ |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{13}$ | - |
| 20 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{14}$ |  |  |  | $+C_{8} \times{ }_{14}$ | - |
| 21 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $\downarrow$ |  | $+\mathrm{C}_{3} \times \mathrm{X}_{15}$ |  |  |  | $+C_{7} \times x_{15}$ | CELL O(Y15) |
| 22 | 0 | $\mathrm{c}_{0} \times \mathrm{X}_{16}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{16}$ |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{16}$ | CELL 1 (Y16) |
| 23 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{17}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{17}$ |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{17}$ | CELL 2 (Y17) |
| 24 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{18}$ | $\downarrow$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{18}$ | CELL3(Y18) |
| 25 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{19}$ | $\downarrow$ |  | $+\mathrm{C}_{3} \times \mathrm{X}_{19}$ | CELL 4 (Y19) |
| 26 | 0 | 0 | 0 | 0 | 0 | $\mathrm{c}_{0} \times \mathrm{X}_{20}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{20}$ | CELL 5(Y20) |
| 27 | 0 | 0 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{21}$ | $+C_{1} \times \mathrm{X}_{21}$ | CELL 6(Y21) |
| 28 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{22}$ | CELL 7 (Y22) |
| 29 | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 30 | $+\mathrm{C}_{14} \times \mathrm{X}_{9}$ | $\mathrm{C}_{15} \times \mathrm{X}_{9}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 31 | $+\mathrm{C}_{13} \times \mathrm{X}_{10}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{10}$ | 0 | 0 | 0 | 0 | 0 | - |
| 32 | $+C_{12} \times \mathrm{X}_{11}$ |  |  | $c_{15} \times x_{11}$ | 0 | 0 | 0 | 0 | - |
| 33 | $+\mathrm{C}_{11} \times \mathrm{X}_{12}$ |  |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{12}$ | 0 | 0 | 0 | - |
| 34 | $+\mathrm{C}_{10} \times \mathrm{X}_{13}$ |  |  |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{13}$ | 0 | 0 | - |
| 35 | +C9 ${ }^{1} \times 14$ |  |  |  |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{14}$ | 0 | - |
| 36 | $+C_{8} \times{ }_{15}$ |  |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{15}$ | - |
| 37 | $+C_{7} \times{ }^{16}$ |  |  |  |  |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{16}$ | - |
| 38 | $+C_{6} \times{ }_{17}$ |  |  |  |  |  |  | $+C_{13} \times{ }^{17}$ | - |
| 39 | $+\mathrm{C}_{5} \times \mathrm{X}_{18}$ |  |  |  |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{18}$ | - |
| 40 | $+\mathrm{C}_{4} \times \mathrm{X}_{19}$ |  |  |  |  |  |  | $+C_{11} \times{ }^{19}$ | - |
| 41 | $+\mathrm{C}_{3} \times \mathrm{X}_{20}$ |  |  |  |  |  |  | $+\mathrm{C}_{10} \times{ }^{20}$ | - |
| 42 | $+C_{2} \times{ }_{21}$ |  |  |  |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{21}$ | - |
| 43 | $+\mathrm{C}_{1} \times \mathrm{X}_{22}$ |  |  |  |  |  |  | $+\mathrm{C}_{8} \times \mathrm{x}_{22}$ | - |
| 44 | $+\mathrm{C}_{0} \times \mathrm{X}_{23}$ | $\downarrow$ |  |  |  |  |  | $+C_{7} \times{ }_{23}$ | CELLO(Y23) |
| 45 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{24}$ | $\downarrow$ |  |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{24}$ | CELL 1 (Y24) |
| 46 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{25}$ |  |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{25}$ | CELL 2 (Y25) |
| 47 | 0 | 0 | 0 | $\mathrm{C}_{0} \times{ }^{26}$ | $\downarrow$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{26}$ | CELL 3(Y26) |
| 48 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{27}$ | $\downarrow$ | $\downarrow$ | $+\mathrm{C}_{3} \times \mathrm{x}_{27}$ | CELL 4(Y27) |

$T p=7+L$ cycles and computes eight output samples. In pass $i$, the sample with indices $i^{*} 8$ to $i^{*} 8+(L-1)$ enter the DINO-7 inputs. The coefficients $C_{0}-C_{L}-1$ enter the CINO-7 inputs, followed by seven zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filing of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient and Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $8 \times 8$ and combine these partial products by shifting and adding to obtain the final result. The shifting and adding can be
accomplished with external adders (at full speed) or with the DF's shift-and-add mechanism contained in its output stage (at reduced speed).

## Decimation/Resampling

The HSP43881 DF provides a mechanism for decimating by factors of 2,3 , or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient path through the cell. These allow the coefficients to be delayed by 1,2 , or 3 clocks through the cell. The sequence table (Table 3) for a decimate-by-two- filter illustrates the technique (internal cell pipelining ignored for simplicity).

Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 16-tap FIR filter, including pipelining, is shown in Figure 7. This filter requires only a single HSP43881 DF.


FIGURE 6. HSP43881 16-TAP 3OMHz FIR FILTER TIMING USING TWO CASCADED HSP43881s

TABLE 3. HSP43881 16-TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE; 30MHz IN, 15 MHz OUT


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL. 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 8 | $+\mathrm{C}_{13} \times \mathrm{X}_{2}$ | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 9 | $+C_{12} \times X_{3}$ |  | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 10 | $+\mathrm{C}_{11} \times \mathrm{X}_{4}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | 0 | 0 | - |
| 11 | $+\mathrm{C}_{10} \times \mathrm{X}_{5}$ |  |  | 0 | 0 | 0 | 0 | 0 | - |
| 12 | $+\mathrm{C}_{9} \times \mathrm{X}_{6}$ |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{6}$ | 0 | 0 | 0 | 0 | - |
| 13 | $+C_{8} \times X_{7}$ |  |  |  | 0 | 0 | 0 | 0 | - |
| 14 | $+\mathrm{C}_{7} \times \mathrm{X}_{8}$ |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | - |
| 15 | $+C_{6} \times X_{9}$ |  |  |  |  | 0 | 0 | 0 | - |
| 16 | $+C_{5} \times{ }_{10}$ |  |  |  |  | $C_{15} \times{ }_{10}$ | 0 | 0 | - |
| 17 | $+C_{4} \times \mathrm{X}_{11}$ |  |  |  |  |  | 0 | 0 | - |
| 18 | $+c_{3} \times x_{12}$ |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{12}$ | 0 | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ |  |  |  |  |  |  | 0 | - |
| 20 | $+C_{1} \times X_{14}$ |  |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{14}$ | - |
| 21 | $+C_{0} \times X_{15}$ |  |  |  |  |  |  | $+C_{14} \times \mathrm{X}_{15}$ | CELLO(Y15) |
| 22 | $\mathrm{C}_{15} \times \mathrm{X}_{16}$ |  |  |  |  |  |  | $+C_{13} \times X_{16}$ | CEL ${ }^{-}$(Y17) |
| 23 | $+\mathrm{C}_{14} \times \mathrm{X}_{17}$ |  |  |  |  |  |  | $+C_{12} \times X_{17}$ | CELL 1 (Y17) |
| 24 | $+\mathrm{C}_{13} \times \mathrm{X}_{18}$ |  |  |  |  |  |  | $+\mathrm{C}_{11} \times \mathrm{X}_{18}$ | - |
| 25 | $+\mathrm{C}_{12} \times \mathrm{X}_{19}$ |  |  |  |  |  |  | $+C_{10} \times x_{19}$ | CELL 2 (Y19) |
| 26 | $+C_{11} \times X_{20}$ |  |  |  |  |  |  | $+\mathrm{Cg}_{9} \mathrm{X}_{20}$ | - |
| 27 | $+\mathrm{C}_{10} \times \mathrm{X}_{21}$ |  |  |  |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{21}$ | CELL 3 (Y21) |
| 28 | $+\mathrm{C}_{9} \times \mathrm{X}_{22}$ |  |  |  |  |  |  | $+C_{7} \times X_{22}$ | - |
| 29 | $+C_{8} \times \times_{23}$ |  |  |  |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{23}$ | CELL 4 (Y23) |
| 30 | $+C_{7} \times X_{24}$ |  |  |  |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{24}$ | - |
| 31 | $+C_{6} \times X_{25}$ |  |  |  |  |  |  | $+C_{4} \times X_{25}$ | CELL 5 (Y25) |
| 32 | $+\mathrm{C}_{5} \times \mathrm{X}_{26}$ |  |  |  |  |  |  | $+C_{3} \times{ }_{26}$ | - |
| 33 | $+C_{4} \times X_{27}$ |  |  |  |  |  |  | $+\mathrm{C}_{2} \times \mathrm{X}_{27}$ | CELL 6 (Y27) |
| 34 | $+C_{3} \times X_{28}$ |  |  |  |  |  |  | $+\mathrm{C}_{1} \times \mathrm{X}_{28}$ | - |
| 35 | $+C_{2} \times X_{29}$ |  |  |  |  |  |  | $+\mathrm{C}_{0} \times{ }_{29}$ | CELL 7 (Y29) |
| 36 | $+C_{1} \times \times_{30}$ | $\checkmark$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\mathrm{C}_{15} \times \mathrm{X}_{30}$ |  |
| 37 | $+\mathrm{C}_{0} \times \mathrm{X}_{31}$ | $+C_{14} \times \times_{31}$ | $+C_{14} \times X_{31}$ | $+C_{14} \times X_{31}$ | $+C_{14} \times{ }_{31}$ | $+C_{14} \times \mathrm{X}_{31}$ | $+C_{14} \times \times_{31}$ | $+C_{14} \times x_{31}$ | CELL 8 (Y31) |
| 1 |  |  |  |  |  | $1$ | $\downarrow$ |  | 1 |



FIGURE 7. HSP43881 16-TAP DECIMATE-BY-TWO FIR FILTER TIMING; 30MHz IN, 15MHz OUT

## Specifications HSP43881

Absolute MaxImum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| input, Output Voltage | . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature. | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD | Class 1 |
| Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$ | . 2.4W (PLCC), 2.88W (PGA) |
| $\theta_{\text {jc }}$ | $11.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $7.78{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| $\theta_{\text {ja }}$ | . $33.7^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $34.66^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Gate Count | ...... 17763 |
| Junction Temperature | .. $150^{\circ} \mathrm{C}$ (PLCC), $175^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering 10s) | $\ldots . .300^{\circ} \mathrm{C}$ |
| CAUTION: Stresses above those listed in the "Abso and operation of the device at these or any other co | age to the device. This is a stress only rating ections of this specification is not implied. |

## Operating Conditions

> Operating Voltage Range
> Operating Temperature Range ..................................................................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 140 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Max CLK Frequency 20MHz Note 1, Note 3 |
| cosse | Stanutiy Föveri Süpuy Cuilieni | - | 500 | $\mu \hat{A}$ | VCC = Max, Note s |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=$ Max |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| VOH | Logical One Output Voltage | 2.6 | - | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=$ Max |
| VILC | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{CIN}^{\text {N }}$ | Input Capacitance PLCC <br>  PGA | - | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency $\mathbf{1 M H z}$ All measurements referenced |
| COUT | $\begin{array}{ll}\text { Output Capacitance } & \text { PLCC } \\ & \text { PGA }\end{array}$ |  | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \text {, Note } 2$ |

notes:

1. Operating supply current is proportional to frequency. Typical rating is $7 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Output load per test load circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | $-30(30 \mathrm{MHz})$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| TCP | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| TCL | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| $\mathrm{TIH}^{\text {H }}$ | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 24 | - | 20 | - | 18 | ns |  |
| TOED | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| - TODS | CLK to SUM Output Delay | - | 27 | - | 25 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | $\cdots$ | 6 | - | 6 | ns | Note 1 |
| TOF | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE:

1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCsB and ICCOP Tests

## Waveforms



CLOCK AC PARAMETERS


* SUM0-25, COUT0-7, TCCO are assumed not to be in high-impedance state

SUMO-25, COUTO-7, TCCO OUTPUT DELAYS


OUTPUT ENABLE, DISABLE TIMING


* Input includes: DINO-7, CINO-7, DIENB, CIENB, ERASE, RESET, DCMO-1, ADRO-2, TCS, TCCI, SHADD

INPUT SETUP AND HOLD


OUTPUT RISE AND FALL TIMES

A.C. Testing: Inputs are driven at 3.0 V for Logic " 1 " and 0.0 V for Logic " 0 ". input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

HARRIS
SEMICONDUCTOR

Digital Filter

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $\mathbf{0 M H z}$ to $\mathbf{2 5 . 6 M H z}$ Sample Rate
- Elight Fllter Celis
- 8-Bit Coefficients and Signal Data
- Low Power CMOS Operation
- Iccse $500 \mu$ A Maximum
- Iccop 160 mA Maximum at 20 MHz
- 26-Bit Accumulator Per Stage
- Filter Lengths Up to 1032 Taps
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP43881GM-20/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43881GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The HSP43881/883 is a video speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $8 \times 8$-bit multiplier, three decimation registers and a 26 -bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 -bits. The HSP43881/883 has a maximum sample rate of 25.6 MHz . The effective multiply accumulate (mac) rate is 204 MHz .

The HSP43881/883 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and $\mathrm{N} \times \mathrm{N}$ spatial correlations/convolutions for image processing applications.

## Block Diagram



Pinouts
85 PIN GRID ARRAY (PGA)


Note: An overbar on a signal name represents an active LOW signal.

## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{j c}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $34.66^{\circ} \mathrm{C} / \mathrm{W}$ | $7.78{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package |  | 1.44 Watt |
| Gate Count |  | 762 Gat |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V
Operating Temperature Range $\qquad$ $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP43881/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}^{2}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{IHC}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & \mathrm{f}=20.0 \mathrm{MHz} \\ & \mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq T_{\text {A }} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8.0 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. HSP43881/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | TCP | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | TCL | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | TCH | Note 1 | 9, 10, 11 | $-55{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | TIS | Note 1 | 9, 10,11 | $-55{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | $\mathrm{T}_{\mathrm{i}} \mathrm{H}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | ToEd | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10,11 | $-55{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0V.

TABLE 3. HSP43881/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -20 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{CIN}_{\text {IN }}$ | $V_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $C_{L}=40 \mathrm{pF}$.
table 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

## Burn-In Circuit

## HSP43881/883 PIN GRID ARRAY (PGA)



| PGA PIN | PIN NAME | BURN-IN SIGNAL | $\left\lvert\, \begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}\right.$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{array}{\|l\|} \text { PGA } \\ \text { PIN } \end{array}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | $V_{S S}$ | GND | C1 | COUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F10 | $V_{C C}$ | $V_{C C}$ | K4 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| A2 | COENB | F10 | C2 | COUT6 | $\mathrm{v}_{\mathrm{CC} / 2}$ | F11 | $\mathrm{V}_{\text {SS }}$ | GND | K5 | SUM19 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A3 | VCC | $V_{C C}$ | C3 | ALIGN | NC | G1 | ADR2 | F2 | K6 | $V_{S S}$ | GND |
| A4 | RESET | F11 | C5 | $\overline{\text { DIENB }}$ | F10 | G2 | DCM0 | F5 | K7 | SUM15 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A5 | DIN7 | F8 | C6 | DIN5 | F5 | G3 | CLK | FO | K8 | SUM12 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A6 | DIN6 | F6 | C7 | DIN4 | F4 | G9 | SUM1 | $\mathrm{V}_{\mathrm{CC}} / 2$ | K9 | SUM10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A7 | DIN3 | F3 | C10 | CIN5 | F5 | G10 | SUM3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K10 | SUM8 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A8 | DINO | FO | C11 | CIN3 | F3 | G11 | SUM2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | SUM6 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A9 | CIN8/TCCI | F8 | D1 | COUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H1 | ADR1 | F1 | L1 | DCM1 | F6 |
| A10 | $V_{\text {CC }}$ | $V_{C C}$ | D2 | COUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H2 | ADRO | FO | L2 | SUM23 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| A11 | $V_{S S}$ | GND | D10 | CIN2 | F2 | H10 | SUM5 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L3 | SUM22 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B1 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | D11 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | H11 | SUM4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L4 | SUM21 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B2 | COUT7 | $\mathrm{v}_{\mathrm{CC}} / 2$ | E1 | COUT1 | $\mathrm{v}_{\mathrm{CC}} / 2$ | J1 | $\mathrm{V}_{\text {CC }}$ | $V_{C C}$ | L5 | SUM18 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B3 | COUT8/TCCO | $\mathrm{V}_{\mathrm{CC} / 2}$ | E2 | $\mathrm{V}_{S S}$ | GND | J2 | SUM25 | $\mathrm{V}_{C C} / 2$ | L6 | SUM14 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B4 | ERASE | F10 | E3 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J5 | SUM20 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L7 | $V_{C C}$ | $V_{C C}$ |
| B5 | DIN8/TCS | F7 | E9 | CIN1 | F1 | J6 | SUM17 | $\mathrm{v}_{\mathrm{CC}} / 2$ | L8 | SUM13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B6 | DIN1 | F1 | E10 | CINO | FO | J7 | SUM16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L9 | $\mathrm{V}_{S S}$ | GND |
| B7 | DIN2 | F2 | E11 | SENBL | F10 | J10 | SUM7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | $L 10$ | SUM11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B8 | CIENB | F10 | F1 | $V_{S S}$ | GND | d11 | $V_{S S}$ | GND | L11 | SUM9 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B9 | CIN7 | F7 | F2 | COUTO | $\mathrm{V}_{\mathrm{CC}} / 2$ | K1 | SENBH | F10 |  |  |  |
| B10 | CIN6 | F6 | F3 | SHADD | F9 | K2 | SUM24 | $\mathrm{V}_{\mathrm{CC} / 2}$ |  |  |  |
| B11 | CIN4 | F4 | F9 | SUMO | VCC/2 | K3 | VSS | GND |  |  |  |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per device.
3. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
4. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2,40 \%-60 \%$ Duty Cycle.
5. Input voltage Limits: $\mathrm{V}_{\mathrm{fL}}=0.8 \mathrm{~V}$ Max, $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Die Characteristics

DIE DIMENSIONS:
$328 \times 283 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10kÅ
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HSP43881/883


## Features

- Eight Filter Cells
- 0 MHz to 30 MHz Sample Rate
- 9-Bit Coefficients and Signal Data
- 26-Bit Accumulator per Stage
- Filter Lengths Over 1000 Taps
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :--- | :--- |
| HSP43891VC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43891VC- 25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43891VC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP43891JC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43891JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43891JC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP43891GC- 20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43891GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43891GC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The HSP43891 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $9 \times 9$ two's complement multiplier, three decimation registers and a 26 -bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 -bits. The HSP43891 has a maximum sample rate of 30 MHz . The effective multiply-accumulate (mac) rate is 240 MHz .

The HSP43891 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8 -bit unsigned or 9 -bit two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three re-sampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and $\mathrm{N} \times \mathrm{N}$ spatial correlations/ convolutions for image processing applications.

## Block Diagram




84 PIN PLASTIC LEADED CHIP CARRIER (PLCC)


Pinouts (Continued)


## Pin Description



## Pin Description (Contlinued)

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { DCMO-1 } \\ \text { (Cont.) } \end{gathered}$ | L1, G2 | 1 | The coefficients pass from cell to cell at a rate determined by the number of decimation registers used. When no decimation registers are used, coefficients move from cell to cell on each clock. When one decimation register is used, coefficients move from cell to cell on every other clock, etc. These signals are latched and delayed by one clock internal to the device. |
| SUMO-25 | $\begin{aligned} & \text { J2, J5-8, } \\ & \text { J10, K2, } \\ & \text { K5-11 } \\ & \text { L2-6, L8, } \\ & \mathrm{L} 10, \mathrm{~L} 11 \end{aligned}$ | 0 | These 26 three-state outputs are used to output the results of the internal filter cell computations. Individual filter cell results or the result of the shift-and-add output stage can be output. If an individual filter cell result is to be output, the ADRO-2 signals select the filter cell result. The SHADD signal determines whether the selected filter cell result or the output stage adder result is output. The signals SENBH and SENBL enable the most significant and least significant bits of the SUMO-25 result respectively. Both $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ may be enabled simultaneously if the system has a 26-bit or larger bus. However individual enables are provided to facilitate use with a 16 -bit bus. |
| $\overline{\text { SENBH }}$ | K1 | 1 | A low on this input enables result bits SUM16-25. A high on this input places these bits in their high impedance state. |
| $\overline{\text { SENBL }}$ | E11 | I | A low on this input enables result bits SUMO-15. A high on this input places these bits in their high impedance state. |
| ADRO-2 | G1, H1, H2 | I | These three inputs select the one cell whose accumulator will be read through the output bus (SUMO-25) or added to the output stage accumulator. They also determine which accumulator will be cleared when ERASE is low. These inputs are latched in the DF and delayed by one clock internal to the device. If ADRO-2 remains at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADRO-2 selects the cell, will be output. This does not hinder normal operation since the ADRO-2 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock. |
| SHADD | F3 | 1 | The SHADD input controls the activation of the shift and add operation in the output stage. This signal is latched on chip and delayed by one clock internal to the device. Detailed explanation is given in the DF Output Stage section. |
| $\overline{\text { RESET }}$ | A4 | 1 | A low on this input synchronously clears all the internal registers, except the cell accumulators it can be used with ERASE to also clear all the accumulators simultaneously. This signal is latched in the DF and delayed by one clock internal to the device. |
| ERASE | B4 | 1 | A low on this input synchronously clears the cell accumulator selected by the ADRO-2 signals. If RESET is also low simultaneously, all cell accumulators are cleared. |

## Functional Description

The Digital Filter Processor (DF) is composed of eight filter cells cascaded together and an output stage for combining or selecting filter cell outputs (See Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 9-bit coefficient is multiplied by a 9 -bit data sample, with the result added to the 26-bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

A 9-bit coefficient (CINO-8) enters each cell through the C register on the left and exits the cell on the right as signals COUT0-8. With no decimation, the coefficient moves directly from the C register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1, 2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).
The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-8) are connected to the CINO-8 inputs of the next cell to its right. The COENB input signal enables the COUTO-8 outputs of the right most cell to the COUTO-8 pins of the device.
The $C$ and $D$ registers are enabled for loading by CIENB. Loading is synchronous with CLK when CIENB is low. Note that CIENB is latched internally. It enables the register for loading after the next CLK following the onset of CIENB Iow. Actual loading oceurs on the second CIK following the onset of $\overline{C I E N B}$ low. Therefore $\overline{C I E N B}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-8 inputs. In most basic FIR operations, CIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When CIENB is high, the coefficients are frozen.
These registers are cleared synchronously under control of $\overline{R E S E T}$, which is latched and delayed exactly like $\overline{\text { CIENB. }}$
The output of the C register ( $\mathrm{CO}-8$ ) is one input to $9 \times 9$ multiplier.

The other input to the $9 \times 9$ multiplier comes from the output of the X register. This register is loaded with a data sample from the device input signals DINO-8 discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when DIENB is low. Note that DIENB is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Actual loading occurs on the second CLK following the onset of DIENB low; therefore, DIENB must be low during the clock cycle immediately preceding presentation of the data sample on the DINO-8 inputs. In most basic FIR operations, DIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the $X$ register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1 (Figure 1). The multiplier output is sign extended and input as one operand of the 26 -bit adder. The other adder operand is the output of the 26-bit accumulator. The
adder output is loaded synchronously into both the accumulator and the TREG.
The TREG loading is disabled by the cell select signal, CELLn, where $n$ is the cell number. The cell select is decoded from the ADRO-2 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.
The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When RESET and ERASE are both low, the accumulator is cleared along with all other registers on the device. Since ERASE and RESET are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and RESET low.
The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, CELLn, decoded from ADRO-2 and the ERASE signal enable clearing of the accumulator on the next CLK.
The ERASE and $\overline{R E S E T}$ signals clear the DF internal registers and states as follows:

| ERASE | $\overline{\text { RFSET }}$ | CIEAR!NC EEFECT |
| :---: | :---: | :--- |
| 1 | 1 | No clearing occurs, internal state <br> remains same. |
| 1 | 0 | $\overline{\text { RESET only active, all registers except }}$ <br> accumulators are cleared, including <br> the internal pipeline registers. |
| 0 | 1 | ERASE only active, the accumulator <br> whose address is given by the ADRO-2 <br> inputs is cleared. |
| 0 | 0 | Both $\overline{R E S E T}$ and $\overline{\text { ERASE }}$accumulators as well as all other <br> registers are cleared. |

## The DF Output Stage

The output stage consists of a 26-bit adder, 26-bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26-bit three-state driver stage (Figure 2).
The 26-bit output adder can add any filter cell accumulator result to the 18 most significant bits of the output buffer. This result is stored back in the output buffer. This operation takes place in one clock period. The eight LSBs of the output buffer are lost. The filter cell accumulator is selected by the ADRO-2 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the output buffer 18 MSBs or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. The SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43891 DF FILTER CELL


FIGURE 2. HSP43891 DFP OUTPUT STAGE

The 26 least significant bits (LSBs) from either a cell accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-2 or the output buffer is output to the bus. This mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-2. Otherwise the output mux selects the contents of the output buffer.

If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-2 selects the cell will be output.

This does not hinder normal FIR operation since the ADRO-2 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock.
The SUM0-25 output bus is controlled by the $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26-bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 10 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either 8-bit unsigned or 9-bit two's complement numbers. The $9 \times 9$ bit multiplier in each cell expects 9 -bit two's complement operands. The binary format of 8-bit two's complement is shown below. Note that if the most significant or sign bit is held at logical zero, the 9-bit two's complement multiplier can multiply 8-bit unsigned operands. Only the upper (positive) half of the two's complement binary range is used.

The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum of products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. Then maximum numbers of terms in the oum products are:

| NUMBER SYSTEM |  | MAX \# OF TERMS |  |
| :--- | :---: | :---: | :---: |
|  | 8-BIT | 9-BIT |  |
| Two unsigned vectors | 1032 | N/A |  |
| Two two's complement vectors: |  |  |  |
| - Two positive vectors | 2080 | 1032 |  |
| - Negative vectors | 2047 | 1024 |  |
| - One positive and one negative vector | 2064 | 1028 |  |
| One unsigned 8 bit vector and one two's |  |  |  |
| complement vector: |  |  |  |
| - Postive two's complement vector | 1036 | 1032 |  |
| - Negative two's complement vector | 1028 | 1028 |  |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple, 30 MHz 8 -tap filter example serves to illustrate more clearly the operation of the DF. The sequence table (Table 1) shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn , enters the DF from
the top, with each cell receiving the same sample simultaneously. Each cell accumulates the sum of products for one output point. Eight sums of products are calculated simultaneously, but staggered in time so that a new output is available every system clock.

TABLE 1. HSP43891 30MHz, 8-TAP FIR FILTER SEQUENCE


| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $C_{7} \times{ }_{0}$ | 0 | 0 | 0 | - | - | - | - | - |
| 1 | $+c_{6} \times x_{1}$ | $\mathrm{C}_{7} \times \mathrm{X}_{1}$ | 0 | 0 | - | - | - | - | - |
| 2 | $+C_{5} \times{ }_{2}$ | $+C_{6} \times x_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 | - | - | - | - | - |
| 3 | $+C_{4} \times{ }^{3}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{3}$ | $+C_{6} \times{ }^{3}$ | $\mathrm{C}_{7} \times{ }^{\text {3 }}$ | - | - | - | - | - |
| 4 | $+C_{3} \times x_{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{4}$ | $+C_{5} \times{ }^{4}$ | $+C_{6} \times \times_{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ | - | - | - | - |
| 5 | $+C_{2} \times{ }_{5}$ | $+\mathrm{C}_{3} \times \mathrm{x}_{5}$ | $+C_{4} \times{ }^{2}$ | $+C_{5} \times{ }^{5}$ | $+C_{6} \times{ }_{5}$ | $\mathrm{C}_{7} \times \mathrm{X}_{5}$ | - | - | - |
| 6 | $+C_{1} \times x_{6}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{6}$ | $+c_{3} \times{ }^{6}$ | $+C_{4} \times{ }^{6}$ | $+C_{5} \times x_{6}$ | $+c_{6} \times x_{6}$ | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ | - | - |
| 7 | $+c_{0} \times x_{7}$ | $+C_{1} \times{ }^{1}$ | $+C_{2} \times{ }^{4}$ | $+c_{3} \times x_{7}$ | $+c_{4} \times{ }^{4}$ | $+C_{5} \times{ }^{4}$ | $+C_{6} \times x_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | Cell 0 (Y7) |
| 8 | $\mathrm{C}_{7} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{8}$ | $+C_{1} \times x_{8}$ | $+C_{2} \times{ }_{8}$ | $+c_{3} \times{ }^{8}$ | $+C_{4} \times{ }^{8}$ | $+C_{5} \times{ }^{8}$ | $+C_{6} \times x_{8}$ | Cell 1 (Y8) |
| 9 | $+C_{6} \times{ }^{\prime}$ | $\mathrm{C}_{7} \times \mathrm{X}_{9}$ | $+C_{0 \times 1}$ | $+c_{1} \times{ }^{1} 9$ | $+C_{2} \times{ }^{2}$ | $+C_{3} \times{ }_{9}$ | $+C_{4} \times{ }^{1}$ | $+C_{5} \times{ }^{4}$ | Cell 2 (Y9) |
| 10 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ | $+C_{6} \times{ }^{10}$ | $\mathrm{C}_{7} \times \mathrm{X}_{10}$ | $+c_{0} \times{ }_{10}$ | $+C_{1} \times{ }_{10}$ | $+C_{2} \times{ }_{10}$ | $+C_{3} \times \times_{10}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{10}$ | Cell 3 (Y10) |
| 11 | $+C_{4} \times \mathrm{X}_{11}$ | $+C_{5} \times \mathrm{X}_{11}$ | $+c_{6} \times{ }_{11}$ | $\mathrm{C}_{7} \times \mathrm{X}_{11}$ | $+c_{0} \times{ }_{11}$ | $+C_{1} \times{ }_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+c_{3} \times x_{11}$ | Cell 4 (Y11) |
| 12 | $+C_{3} \times \mathrm{X}_{12}$ | $+C_{4} \times{ }_{12}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{12}$ | $+C_{6} \times{ }_{12}$ | $\mathrm{C}_{7} \times \mathrm{X}_{12}$ | $+C_{0} \times{ }_{12}$ | $+C_{1} \times{ }_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell 5 (Y12) |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+C_{3} \times{ }_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{13}$ | $+C_{6} \times{ }_{13}$ | $\mathrm{C}_{7} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{13}$ | $+C_{1} \times{ }_{13}$ | Cell 6 (Y13) |
| 14 | $+C_{1} \times{ }_{14}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{14}$ | $+C_{3} \times{ }_{14}$ | $+C_{4} \times{ }_{14}$ | $+C_{5} \times \mathrm{X}_{14}$ | $+C_{6} \times{ }_{14}$ | $+C_{7} \times{ }_{14}$ | $+c_{0} \times{ }_{14}$ | Cell 7 (Y14) |
| 15 | $+c_{0} \times{ }_{15}$ | $+C_{1} \times{ }_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+c_{3} \times{ }_{15}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{15}$ | $+C_{5} \times{ }_{15}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{15}$ | $\mathrm{C}_{7} \times \mathrm{X}_{15}$ | Cello (Y15) |



FIGURE 3. HSP43891 30MHz, 8-TAP FIR FILTER APPLICATION SCHEMATIC

Detailed operation of the DF to perform a basic 8-tap, 9-bit coefficient, 9 -bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram (Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore the delay from presentation of data and coefficients at the DINO-8 and CINO-8 inputs to a sum appearing at the SUMO-25 output is: $k+$ Td, where $k=$ filter length and $T \mathrm{~d}=4$, the internal pipeline delay of the DF.

After the pipeline has filled, a new output sample is available every clock. The delay to last sample output from last sample input is Td.

The output sums, Yn , shown in the timing diagram are derived from the sum-of-products equation:
$\mathrm{Y}(\mathrm{n})=\mathrm{C}(0) \times \mathrm{X}(\mathrm{n})+\mathrm{C}(1) \times \mathrm{X}(\mathrm{n}-1)+\mathrm{C}(2) \times \mathrm{X}(\mathrm{n}-2)+\mathrm{C}(3)$ $x X(n-3)+C(4) \times X(n-4)+C(5) \times X(n-5)+C(6) \times X(n-6)$
$+C(7) \times X(n-7)$






$$
Y_{N}=\sum_{K=0}^{7} c_{K} \times x_{N-K}
$$

FIGURE 4. HSP43891 30MHz, 8-TAP FIR FILTER TIMING


FIGURE 5. HSP43891 30 MHz , 16 -TAP FIR FILTER CASCADE APPLICATION SCHEMATIC

## Extended FIR Filter Length

Filter lengths greater that eight taps can be created by either cascading together multiple DF devices or "reusing" a single device. Using multiple devices, an FIR filter of over 1000 taps can be constructed to operate at a 30 MHz sample rate. Using a single device clocked at 30 MHz , an FIR filter of over 500 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.

## Cascade Configuration

To design a filter length $L>8, L / 8$ DFs are cascaded by connecting the COUTO-8 outputs of the (i)th DF to the CINO-8 inputs of the (i+1)th DF. The DINO-8 inputs and SUMO-25 outputs of all the DFs are also tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 8-tap FIR, except the ERASE and SENBL/SENBH signals must be enabled independently for the two DFs in order to clear the correct accumulators and enable the SUM0-25 output signals at the proper times.


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - | - | - | - | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | $\mathrm{C}_{15} \times \mathrm{X}_{1}$ | 0 | 0 | - | - | - | - | - |
| 8 | $+\mathrm{C}_{13} \times \mathrm{X}_{2}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 | - | - | - | - | - |
| 9 | $+\mathrm{C}_{12 \times} \times{ }^{\text {a }}$ |  |  | $\mathrm{C}_{15} \times{ }^{\text {3 }}$ | - | - | - | - | - |
| 10 | $+C_{11} \times x_{4}$ |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | - | - | - | - |
| 11 | $+C_{10 \times} \times{ }_{5}$ |  |  | $+C_{13} \times{ }_{5}$ |  | $\mathrm{c}_{15} \times \mathrm{X}_{5}$ | - | - | - |
| 12 | $+\mathrm{Cg}_{9} \times \mathrm{X}_{6}$ |  |  | $+C_{12} \times x_{6}$ |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{6}$ | ${ }^{-}$ | - |
| 13 | $+C_{8} \times{ }^{4}$ |  |  | $+C_{11} \times{ }^{1}$ |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{7}$ | - |
| 14 | $+C_{7} \times x_{8}$ |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{8}$ |  |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{8}$ | - |
| 15 | $+C_{6} \times{ }^{4}$ |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{9}$ |  |  |  | $+\mathrm{C}_{13} \times \mathrm{X}_{9}$ | - |
| 16 | $+C_{5} \times{ }^{10}$ |  |  | $+C_{8} \times{ }^{10}$ |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{10}$ | - |
| 17 | $+\mathrm{C}_{4} \times \mathrm{X}_{11}$ |  |  | $+C_{7} \times x_{11}$ |  |  |  | $+\mathrm{C}_{11} \times \mathrm{X}_{11}$ | - |
| 18 | $+\mathrm{C}_{3} \times \mathrm{X}_{12}$ |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{12}$ |  |  |  | $+C_{10} \times \mathrm{X}_{12}$ | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ |  |  | $+C_{5} \times \mathrm{X}_{13}$ |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{13}$ | - |
| 20 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{14}$ |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{14}$ | - |
| 21 | $+c_{0} \times{ }^{15}$ | $\downarrow$ |  | $+C_{3} \times{ }_{15}$ |  |  |  | $+C_{7} \times{ }^{15}$ | Cell O(Y15) |
| 22 | 0 | $\mathrm{c}_{0} \times{ }^{16}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{16}$ |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{16}$ | Cell 1(Y16) |
| 23 | 0 | 0 | $c_{0 \times 17}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{17}$ |  |  |  | $+C_{5} \times \mathrm{X}_{17}$ | Cell 2(Y17) |
| 24 | 0 | 0 | 0 | $+C_{0} \times{ }_{18}$ | $\downarrow$ |  |  | $+C_{4} \times \mathrm{X}_{18}$ | Cell 3(Y18) |
| 25 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{19}$ | $\downarrow$ |  | $+C_{3} \times x_{19}$ | Cell 4(Y19) |
| 26 | 0 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{20}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{20}$ | Cell 5(Y20) |
| 27 | 0 | 0 | 0 | 0 | 0 | 0 | $\mathrm{c}_{0} \times \mathrm{X}_{21}$ | $+c_{1} \times x_{21}$ | Cell 6(Y21) |
| 28 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $+c_{0} \times{ }_{22}$ | Cell 7(Y22) |
| 29 | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 30 | $+C_{14} \times X_{9}$ | $+C_{15} \times{ }_{9}$ | 0 $+c_{15} \times{ }^{0}$ | 0 | 0 | 0 | 0 | 0 | - |
| 31 | $+C_{13} \times \times_{10}$ $+C_{12} \times \times_{11}$ |  | $+C_{15} \times \mathrm{X}_{10}$ | $\stackrel{0}{0}$ | 0 | 0 | 0 | 0 | - |
| 32 33 |  |  |  | $+\mathrm{C}_{15} \times \mathrm{X}_{11}$ | 0 $+C_{15} \times \mathrm{X}_{12}$ | 0 0 | 0 0 | 0 0 | - |
| 33 34 | $+C_{11} \times{ }^{1} \times 12$ $+C_{10} \times \times_{13}$ |  |  |  |  | $+C_{15} \times \mathrm{X}_{12}$ | 0 | 0 | - |
| 35 |  |  |  |  |  | ${ }^{+C_{15} \times \times 12}$ | $+\mathrm{C}_{15} \times \mathrm{X}_{14}$ | 0 | - |
| 36 | $+\mathrm{C}_{8} \times{ }^{15}$ |  |  |  |  |  | $1$ | $c_{15} \times X_{15}$ | - |
| 37 38 | $+C_{7} \times \times_{16}$ $+C_{6} \times x_{17}$ |  |  |  |  |  |  | $+C_{14} \times x_{16}$ | - |
| 38 39 | $+C_{6} \times \times_{17}$ $+C_{5} \times x_{18}$ |  |  |  |  |  |  | + $\mathrm{C}_{13} \times \mathrm{X}_{17}$ | - |
| 39 40 |  |  |  |  |  |  |  | $+C_{12} \times \times_{18}$ <br> $+C_{11} \times \times_{19}$ | - |
| 41 | $+C_{4} \times \times_{19}$ $+C_{3} \times \times 20$ |  |  |  |  |  |  | $+C_{11} \times \times_{19}$ $+C_{10} \times X_{20}$ | - |
| 42 | $+\mathrm{C}_{2} \times \times 21$ |  |  |  |  |  |  | $+\mathrm{C}_{9} \times \times_{21}$ | - |
| 43 | $+\mathrm{C}_{1} \times \mathrm{X}_{22}$ | 1 |  |  |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{22}$ |  |
| 44 45 | $+c_{0} \times x_{23}$ | $\stackrel{\downarrow}{\square}$ |  |  |  |  |  | $+c_{7} \times x_{23}$ | Cell O(Y23) |
| 45 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{23}$ | $\stackrel{\downarrow}{\square}$ |  | $1$ |  |  | $+\mathrm{C}_{6} \times \mathrm{x}_{24}$ | Cell 1(Y24) Cell 2(Y25) |
| 46 47 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{25}$ | $\stackrel{\downarrow}{\square}$ | $1$ |  |  | $+C_{5} \times \times_{25}$ | Cell 2(Y25) Cell 3(Y26) |
| 47 48 | 0 | 0 0 | 0 0 | $\mathrm{C}_{0} \mathrm{Cl}_{0} \mathrm{X}_{26}$ | $\mathrm{c}_{0} \times{ }^{\downarrow} \times$ | $\downarrow$ | $\downarrow$ | $+C_{4} \times \times_{26}$ $+C_{3} \times \times{ }^{27}$ | Cell 4 (Y27) |



FIGURE 6. HSP43891 16-TAP 30MHz FILTER TIMING USING TWO CASCADED HSP43891s

## Single DF Configuration

Using a single DF, a filter of length $L>8$ can be constructed by processing in L/8 passes, as illustrated in Table 2, for a 16-tap FIR. Each pass is composed of $T p=7+L$ cycles and computes eight output samples. In pass $I$, the sample
 coefficients $\mathrm{C}_{0}-\mathrm{C}_{\mathrm{L}}-1$ enter the CINO-8 inputs, followed by seven zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filing of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient and Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $9 \times 9$ and com-
bine these partial products by shifting and adding to obtain the final result. The shifting and adding can be accomplished with external adders (at full speed) or with the DF's shift-and-add mechanism contained in its output stage (at reduced speed).

## Decimation/Resampling

The HSP43891 DF provides a mechanism for decimating by factors of 2,3 , or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient path through the cell. These allow the coefficients to be delayed by 1,2 , or 3 clocks through the cell. The sequence table (Table 3) for a decimate-by-twofilter illustrates the technique (internal cell pipelining ignored for simplicity).
Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 16-tap FIR filter, including pipelining, is shown in Figure 7. This filter requires only a single HSP43891 DF.

TABLE 3. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE; 30MHz IN, 15 MHz OUT


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $C_{15} \times X_{0}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 8 | $+\mathrm{C}_{13} \times \mathrm{X}_{2}$ | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 9 | $+\mathrm{C}_{12} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{3}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 10 | $+\mathrm{C}_{11} \times \mathrm{X}_{4}$ | $+C_{13} \times X_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | 0 | 0 | - |
| 11 | $+\mathrm{C}_{10} \times \mathrm{X}_{5}$ | $+C_{12} \times X_{5}$ | $+C_{14} \times X_{5}$ | 0 | 0 | 0 | 0 | 0 | - |
| 12 | $+C_{9} \times x_{6}$ | $+C_{11} \times X_{6}$ | $+C_{13} \times x_{6}$ | $\mathrm{C}_{15} \times \mathrm{X}_{6}$ | 0 | 0 | 0 | 0 | - |
| 13 | $+C_{8} \times X_{7}$ | $+C_{10} \times{ }_{7}$ | $+C_{12} \times X_{7}$ | $+C_{14} \times X_{7}$ | 0 | 0 | 0 | 0 | - |
| 14 | $+C_{7} \times X_{8}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{8}$ | $+C_{11} \times X_{8}$ | $+C_{13} \times X_{8}$ | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | - |
| 15 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{10} \times \mathrm{X}_{9}$ | $+C_{12} \times \mathrm{X}_{9}$ | $+C_{14} \times \mathrm{X}_{9}$ | 0 | 0 | 0 | - |
| 16 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ | $+C_{7} \times{ }_{10}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{10}$ | $+C_{11} \times X_{10}$ | $+C_{13} \times X_{10}$ | $\mathrm{C}_{15} \times \mathrm{X}_{10}$ | 0 | 0 | - |
| 17 | $+C_{4} \times X_{11}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{11}$ | $+C_{8} \times \mathrm{X}_{11}$ | $+C_{10} \times{ }_{11}$ | $+C_{12} \times x_{11}$ | $+C_{14} \times X_{11}$ | 0 | 0 | - |
| 18 | $+C_{3} \times X_{12}$ | $+C_{5} \times{ }^{12}$ | $+C_{7} \times X_{12}$ | $+C_{9} \times X_{12}$ | $+C_{11} \times x_{12}$ | $+C_{13} \times X_{12}$ | $\mathrm{C}_{15} \times \mathrm{X}_{12}$ | 0 | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+C_{6} \times{ }_{13}$ | $+C_{8} \times{ }^{13}$ | $+C_{10} \times X_{13}$ | $+C_{12} \times X_{13}$ | $+C_{14} \times X_{13}$ | 0 | - |
| 20 | $+C_{1} \times \mathrm{X}_{14}$ | $+c_{3} \times \mathrm{X}_{14}$ | $+C_{5} \times{ }_{14}$ | $+C_{7} \times X_{14}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{14}$ | $+C_{11} \times \times_{14}$ | $+C_{13} \times \mathrm{X}_{14}$ | $\mathrm{C}_{15} \times \mathrm{X}_{14}$ | - |
| 21 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+C_{4} \times \mathrm{X}_{15}$ | $+C_{6} \times{ }_{15}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{15}$ | $+C_{10} \times \mathrm{X}_{15}$ | $+C_{12} \times \mathrm{X}_{15}$ | $+C_{14} \times X_{15}$ | Cell O(Y15) |
| 22 | $\mathrm{C}_{15} \times \mathrm{X}_{16}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{16}$ | $+C_{3} \times{ }_{16}$ | $+C_{5} \times \mathrm{X}_{16}$ | $+C_{7} \times{ }^{16}$ | $+C_{9} \times{ }_{16}$ | $+C_{11} \times \mathrm{X}_{16}$ | $+C_{13} \times X_{16}$ | - |
| 23 | $+\mathrm{C}_{14} \times \mathrm{X}_{17}$ | $+c_{0} \times X_{17}$ | $+C_{2} \times{ }^{17}$ | $+C_{4} \times \mathrm{X}_{17}$ | $+C_{6} \times{ }_{17}$ | $+C_{8} \times{ }_{17}$ | $+C_{10} \times \mathrm{X}_{17}$ | $+C_{12} \times x_{17}$ | Cell 1(Y17) |
| 24 | $+C_{13} \times X_{18}$ | $\mathrm{C}_{15} \times \mathrm{X}_{18}$ | $+C_{1} \times{ }_{18}$ | $+c_{3} \times x_{18}$ | $+C_{5} \times{ }_{18}$ | $+C_{7} \times \mathrm{X}_{18}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{18}$ | $+C_{11} \times X_{18}$ | (1) |
| 25 | $+\mathrm{C}_{12} \times \mathrm{X}_{19}$ | $+C_{14} \times X_{19}$ | $+C_{0} \times X_{19}$ | $+C_{2} \times X_{19}$ | $+C_{4} \times{ }^{19}$ | $+C_{6} \times \mathrm{X}_{19}$ | $+C_{8} \times{ }_{19}$ | $+C_{10} \times X_{19}$ | Cell 2(Y19) |
| 26 | $+\mathrm{C}_{11} \times \mathrm{X}_{20}$ | $+C_{13} \times \mathrm{X}_{20}$ | $\mathrm{C}_{15} \times \mathrm{X}_{20}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{20}$ | $+C_{3} \times{ }_{20}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{20}$ | $+C_{7} \times{ }_{20}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{20}$ | - |
| 27 | $+\mathrm{C}_{10} \times \mathrm{X}_{21}$ | $+C_{12} \times \mathrm{X}_{21}$ | $+C_{14} \times X_{21}$ | $+C_{0} \times X_{21}$ | $+C_{2} \times \mathrm{X}_{21}$ | $+C_{4} \times \mathrm{X}_{21}$ | $+C_{6} \times{ }_{21}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{21}$ | Cell 3(Y21) |
| 28 | $+\mathrm{C}_{9} \times \mathrm{X}_{22}$ | $+C_{11} \times X_{22}$ | $+C_{13} \times X_{22}$ | $\mathrm{C}_{15} \times \mathrm{X}_{22}$ | $+C_{1} \times{ }_{22}$ | $+C_{3} \times X_{22}$ | $+C_{5} \times{ }_{22}$ | $+C_{7} \times X_{22}$ | - |
| 29 | $+\mathrm{C}_{8} \times \mathrm{X}_{23}$ | $+\mathrm{C}_{10} \times \mathrm{X}_{23}$ | $+C_{12} \times X_{23}$ | $+C_{14} \times X_{23}$ | $+C_{0} \times{ }_{23}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{23}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{23}$ | $+C_{6} \times{ }_{23}$ | Cell 4(Y23) |
| 30 | $+C_{7} \times{ }_{24}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{24}$ | $+C_{11} \times \mathrm{X}_{24}$ | $+C_{13} \times X_{24}$ | $+C_{15} \times{ }_{24}$ | $+C_{1} \times \mathrm{X}_{24}$ | $+C_{3} \times{ }_{24}$ | $+C_{5} \times{ }_{24}$ | - |
| 31 | $+C_{6} \times{ }_{25}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{25}$ | $+C_{10} \times{ }_{25}$ | $+C_{12} \times X_{25}$ | $+C_{14} \times{ }_{25}$ | $+C_{0} \times \mathrm{X}_{25}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{25}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{25}$ | Cell 5(Y25) |
| 32 | $+\mathrm{C}_{5} \times \mathrm{X}_{26}$ | $+C_{7} \times X_{26}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{26}$ | $+C_{11} \times X_{26}$ | $+C_{13} \times X_{26}$ | $+C_{15} \times X_{26}$ | $+C_{1} \times{ }_{26}$ | $+C_{3} \times X_{26}$ | - |
| 33 | $+C_{4} \times \mathrm{X}_{27}$ | $+C_{6} \times X_{27}$ | $+C_{8} \times{ }_{27}$ | $+C_{10} \times X_{27}$ | $+C_{12} \times X_{27}$ | $+C_{14} \times \mathrm{X}_{27}$ | $+C_{0} \times{ }_{27}$ | $+C_{2} \times{ }_{27}$ | Cell 6(Y27) |
| 34 | $+\mathrm{C}_{3} \times \mathrm{X}_{28}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{28}$ | $+C_{7} \times{ }_{28}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{28}$ | $+C_{11} \times X_{28}$ | $+C_{13} \times \mathrm{X}_{28}$ | $+\mathrm{C}_{15} \times \mathrm{X}_{28}$ | $+C_{1} \times X_{28}$ | - |
| 35 | $+\mathrm{C}_{2} \times \mathrm{X}_{29}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{29}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{29}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{29}$ | $+C_{10} \times{ }_{29}$ | $+C_{12} \times \mathrm{X}_{29}$ | $+C_{14} \times X_{29}$ | $+C_{0} \times{ }_{29}$ | Cell 7(Y29) |
| 36 | $+C_{1} \times{ }^{1} \times$ | $+C_{3} \times X_{30}$ | $+C_{5} \times{ }_{30}$ | $+C_{7} \times{ }_{30}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{30}$ | $+C_{11} \times{ }_{30}$ | $+C_{13} \times X_{30}$ | $\mathrm{C}_{15} \times \mathrm{X}_{30}$ | - |
| 37 | $+C_{0} \times X_{31}$ | $+\mathrm{C}_{2} \times \times_{31}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{31}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{31}$ | $+C_{8} \times{ }_{31}$ | $+C_{10} \times \times_{31}$ | $+C_{12} \times x_{31}$ | $+C_{14} \times X_{31}$ | Cell 8(Y31) |



FIGURE 7. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER TIMING; 30 MHz IN, $\mathbf{1 5 M H z}$ OUT

## Absolute Maximum Ratings



Operating Conditions
$\qquad$
D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 140 | mA | $V_{C C}=\operatorname{Max}$ <br> CLK Frequency 20 MHz Note 1, Note 3 |
| ${ }^{\prime} \mathrm{CCSB}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Note 3 |
| $1!$ | Input Leakage Currant | -10 | 10 | \% |  |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voitage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| $\mathrm{V}_{\text {ILC }}$ | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance $\begin{array}{r}\text { PLCC } \\ \\ \hline\end{array}$ |  | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency 1 MHz All measurements referenced |
| Cout | Output Capacitance PLCC <br>  PGA |  | $\begin{array}{r} 10 \\ 15 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | to GND $T_{A}=25^{\circ} \mathrm{C} . \quad \text { Note } 2$ |

NOTES: 1. Operating supply current is proportional to frequency. Typical rating is $7 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | -30 (30MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| $\mathrm{T}_{\mathrm{CP}}$ | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| $\mathrm{T}_{\mathrm{CL}}$ | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| ${ }^{\text {T }} \mathrm{CH}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| $\mathrm{T}_{\mathrm{IH}}$ | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 24 | - | 20 | - | 18 | ns |  |
| TOED | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| TODS | CLK to SUM Output Delay | - | 27 | - | 25 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | - | 6 | - | 6 | ns | Note 1 |
| Tof | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE: 1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Waveforms



CLOCK AC PARAMETERS


SUMO-25, COUTO-8, OUTPUT DELAYS


OUTPUT ENABLE, DISABLE TIMING


RISE AND FALL TIMES

A.C. Testing: Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- OMHz to 25.6 MHz Sample Rate
- Eight Filter Cells
- 9-Bit Coefficients and Signal Data
- Low Power CMOS Operation
- $I_{\text {CCSB }}=500 \mu \mathrm{~A}$ Maximum
- $\mathrm{I}_{\text {ccop }}=160 \mu \mathrm{~A}$ Maximum at 20 MHz
- 26-Bit Accumulator per Stage
- Filter Lengths Up to 1032 Taps
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video
- Adaptive Filters
- Echo Cancellation
- Complex Multiply-Add
- Sample Rate Converters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP43891GM-20/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP43891GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The HSP43891/883 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $9 \times 9$ two's complement multiplier, three decimation registers and a 26 -bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 -bits. The HSP43891/883 has a maximum sample rate of 25.6 MHz . The effective multiply-accumulate (mac) rate is 204 MHz .

The HSP43891/883 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or 9-bit two's complement arithmetic, independently selectable for coefficients and signal data.
Each DF filter cell contains three re-sampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and $N \times N$ spatial correlations/convolutions for image processing applications.

## Block Diagram



## Pinouts

85 PIN GRID ARRAY (PGA)

|  | 1 | 2 | 3 | 4 | 5 | 8 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\wedge$ | vss | COENB | $v_{\text {cc }}$ | $\overline{\text { RESET }}$ | DIN7 | din6 | DIN3 | DINO | CIN8 | $\mathrm{v}_{\mathrm{cc}}$ | Vs3 |
| B | $\mathrm{v}_{\mathrm{cc}}$ | cout7 | COUT8 | ERASE | DINB | DIN1 | DIN2 | $\overline{\text { CIENB }}$ | CIN7 | CIN6 | CIN4 |
| c | cout5 | COUTB | ${ }_{\text {PIN }}^{\text {ALIN }}$ |  | $\overline{\text { DIENB }}$ | DIN5 | DIN4 |  |  | CIN5 | CIN3 |
| D | cour3 | COUT4 |  | HSP43891/883 <br> TOP VIEW. <br> Mins iount |  |  |  |  |  | CIN2 | $v_{c c}$ |
| E | cout 1 | vs3 | cout2 |  |  |  |  |  | CIN1 | CINo | SENEL |
| F | $\mathrm{v}_{\mathbf{S S}}$ | COUTO | SHADD |  |  |  |  |  | sumo | $\mathrm{v}_{\mathrm{cc}}$ | $\mathrm{v}_{\mathbf{S 8}}$ |
| G | ADR2 | dсмо | cuk |  |  |  |  |  | sUms | sum3 | sum? |
| H | ADR1 | ADRO |  |  |  |  |  |  |  | Sum5 | Sum4 |
| J | $\mathrm{V}_{\mathrm{GC}}$ | SUM25 |  |  | SUM20 | SUM 17 | SUM16 |  |  | sum7 | V8s |
| K | $\overline{\text { SENBH }}$ | SUM24 | $\mathrm{v}_{\text {ss }}$ | $\mathrm{v}_{\mathrm{cc}}$ | SUM19 | vss | SUM15 | SUM12 | SUM10 | Sum8 | sumb |
| L | DCM1 | SUM23 | SUM22 | Sum21 | SUM18 | SUM14 | vac | SUM13 | vos | slonit | Suse |




Rellability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | O |
| :---: | :---: | :---: |
| Ceramic PGA Package | $34.66{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $7.78{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125{ }^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package |  |  |
| Gate Count |  | 17762 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . .+4.5 V to +5.5 V
Operating Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP43891/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{H}}$ | $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}^{\mathrm{O}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | VOL | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{\text {CC }} \text { or GND } \\ & V_{\text {CC }}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | VIHC | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $V_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | I'cesb | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES: 1. Interchanging of force and sense conditions is permitted.

[^3]TABLE 2. HSP43891/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | TCP | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | TCL | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | $\mathrm{T}_{\mathrm{CH}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | TIS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | TIH | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | ToED | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: VCC $=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .

TABLE 3. HSP43891/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTTES | TEMPERATIPR | -20 (20MHz) |  | -25 (25.6MHz) |  | UHITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | A!! | MAAX | SAR | A |  |
| Input Capacitance | CIN | $V_{\mathrm{CC}}=\text { Open, } f=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES: 1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 A, 8 B, 10,11$ |
| Group A | - | $1,2,3,7,8 A, 8 B, 9,10,11$ |
| Groups C \&D | Samples/5005 | $1,7,9$ |

## Burn-In Circuit



| PGA PIN | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | PGA PIN | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | $V_{\text {SS }}$ | GND | C1 | COUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F10 | $V_{C C}$ | $V_{C C}$ | K4 | VCC | $\mathrm{V}_{\mathrm{CC}}$ |
| A2 | COENB | F10 | C2 | COUT6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | $V_{\text {SS }}$ | GND | K5 | SUM19 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A3 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | C3 | ALIGN | NC | G1 | ADR2 | F2 | K6 | VSS | GND |
| A4 | RESET | F11 | C5 | DIENB | F10 | G2 | DCM0 | F5 | K7 | SUM15 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A5 | DIN7 | F8 | C6 | DIN5 | F5 | G3 | CLK | FO | K8 | SUM12 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A6 | DIN6 | F6 | C7 | DIN4 | F4 | G9 | SUM1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K9 | SUM10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A7 | DIN3 | F3 | C10 | CIN5 | F5 | G10 | SUM3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K10 | SUM8 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A8 | DINO | FO | C11 | CIN3 | F3 | G11 | SUM2 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K11 | SUM6 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A9 | CIN8/TCCI | F8 | D1 | COUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H1 | ADR1 | F1 | L1 | DCM1 | F6 |
| A10 | $V_{C C}$ | $V_{C C}$ | D2 | COUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H2 | ADRO | FO | L2 | SUM23 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A11 | $V_{S S}$ | GND | D10 | CIN2 | F2 | H10 | SUM5 | $\mathrm{v}_{\mathrm{cc} / 2}$ | L3 | SUM22 | $\mathrm{V}_{\mathrm{Cc} / 2}$ |
| B1 | $V_{\text {cc }}$ | $V_{C C}$ | D11 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{C}}$ | H11 | SUM4 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L4 | SUM21 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| B2 | COUT7 | $\mathrm{V}_{\mathrm{cc}} / 2$ | E1 | COUT1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J1 | $V_{\text {cc }}$ | $V_{C C}$ | L5 | SUM18 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| 83 | COUT8/TCCO | $\mathrm{V}_{\mathrm{Cc} / 2}$ | E2 | $\mathrm{V}_{S S}$ | GND | J2 | SUM25 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L6 | SUM14 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
|  |  |  | E3 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J5 | SUM20 | $\mathrm{VCC} / 2$ | L7 | VCC | $V_{C C}$ |
| B4 | ERASE | F10 | E9 | CIN1 | F1 | J6 | SUM17 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L8 | SUM13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B5 | DIN8/TCS | F7 | E10 | CINO | FO | J7 | SUM16 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L9 | VSS | GND |
| B6 | DIN1 | F1 | E11 | SENBL | F10 | J10 | SUM7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L10 | SUM11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B7 | DIN2 | F2 | F1 | VSS | GND | J11 | VSS | GND | L11 | SUM9 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| 88 | CIENB | F10 | F2 | CUTO | $V_{C C} / 2$ | K1 | SENBH | F10 |  |  |  |
| B9 | CIN7 | F7 | F3 | SHADD | F9 | K2 | SUM24 | $\mathrm{V}_{\mathrm{CC} / 2}$ |  |  |  |
| B10 | CIN6 | F6 | F9 | SUMO | $\mathrm{V}_{\mathrm{CC}} / 2$ | K3 | $\mathrm{V}_{\text {SS }}$ | GND |  |  |  |
| B11 | CIN4 | F4 |  |  |  |  |  |  |  |  |  |

NOTES: 1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except
$V_{C C}$ and GND.
3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $F 0=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, \ldots, F 11=F 10 / 2$, 40\% - 60\% Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max., $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Metallization Topology

DIE DIMENSIONS:
$328 \times 283 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
WORST CASE CURRENT DENSITY:
$1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HSP43891/883


## VIDEO PROCESSING

PAGE

| HSP48212 | Digital Video Mixer | 4-3 |
| :---: | :---: | :---: |
| HSP48410 | Histogrammer/Accumulating Buffer. | 4-12 |
| HSP48410/883 | Histogrammer/Accumulating Buffer | 4-23 |
| HSP48901 | $3 \times 3$ Image Filter | 4-31 |
| HSP48908 | Two Dimensional Convolver | 4-40 |
| HSP48908/883 | Two Dimensional Convolver | 4-57 |
| HSP9501 | Programmable Data Buffer . | 4-64 |

NOTE: Bold Type Designates a New Product from Harris.

## Features

- 12-Bit Pixel Data
- Two's Complement or Unsigned Data
- 12-Bit Mix Factor
- 13-Bit Signed or Unsigned Three State Output
- Overflow Detection and Output Saturation
- Rounding to $8,10,12$, or 13-Blts
- Input and Output Pixel Data Synchronous to Clock
- Programmable Pipeline Delay of up to 7 Clock Cycles for Control of Misallgned Input Data
- TTL Compatible Inputs/Outputs
- DC to 40 MHz Clock Rate


## Applications

- Video Summing (Frame Addition)
- Video Mixing
- Fade InNOut
- Video Switching
- High Speed Multiplying


## Description

The Harris HSP48212 is a 68 pin Digital Video Mixer IC intended for use in multimedia and medical imaging applications.

The HSP48212 allows the user to mix two video sources based on a programmable weighting factor. After weighting the input data signals, the Video Mixer simply adds the two weighted signals mathematically. This results in the mixed output, which is a weighted sum of the two sources.

The input and output interfaces are synchronous with respect to the input clock, simplifying the user interface requirements.

Input Data (DINA, DINB), Mix Factor (M) and control signals (RND, TCB) may be delayed relative to each other in order to compensate for any misalignment that may have occurred prior to entering the HSP48212. Each input's delay may be independently programmed up to seven clock cycles.

The output data may be rounded to $8,10,12$, or 13 -bits. The enabling of data onto the output data bus is under the user's control via an output enable signal (OE\#).

## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE TYPE |
| :--- | :---: | :--- |
| HSP48212VC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 64 Lead MQFP |
| HSP48212JC- 40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |

## Block Diagram



DOUT $=2 \times[$ DINA $\times M+$ DINB $\times(1-M)]$

## Pinouts




## Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CLK | 9 | 1 | Clock input. All signal pins are synchronous with respect to this clock except LD\#, DEL, OE\#, and BYPASS. |
| DINAO-11 | $\begin{aligned} & 29-31 \\ & 33-34 \\ & 36-38 \\ & 40-43 \end{aligned}$ | 1 | Input data bus. Provides data to the Mixer from one video source. Synchronous to the rising edge of CLK. |
| DINBO-11 | $\begin{gathered} 10-15,17 \\ 19-23 \end{gathered}$ | 1 | Input data bus. Provides data to the Mixer from one video source. Synchronous to the rising edge of CLK. |
| M0-11 | $\begin{gathered} 62-65 \\ 67-68 \\ 2-7 \end{gathered}$ | 1 | Mix input bus. The range of $M$ is from 0 to 1 . The number format is unsigned, with one bit position to the left of the binary point. If a value greater than 1 is placed on this bus, the internal circuitry will saturate M to 1 , i.e anytime the MSB is 1 , the internal value defauts to 1.00000000000 . Synchronous to the rising edge of CLK. |
| TC* | 28 | 1 | Specifies the number format of the input data busses DINA and DINB. $1=$ unsigned, $0=2$ 's complement. The signal has the same number of latency stages as the incoming data. Therefore, the number format affects the incoming data but not the data in the internal pipeline stages. Synchronous to the rising edge of CLK. |
| RNDO-1 | 24-25 | 1 | Specifies the number of significant bits on the output bus. $00=8$-bit, $01=10$-bit, $10=12$-bit, $11=13$-bit. Rounding is performed by adding a binary 1 to the bit position to the right of the desired LSB. The remaining bits are forced to zero. These control signals have the same number of latency stages as the incoming data. Therefore, the output round format does not take effect until the current data has propagated to the output. Synchronous to the rising edge of CLK. |
| MIXEN | 8 | 1 | Mix enable. This pin is used to disable the clock signal which samples the Mix input. When MIXEN $=1$, the M0-11 bus is sampled by the rising edge of CLK. When MIXEN $=0$, the M0-11 bus is ignored and the previously stored value of M0-11 is used. Synchronous to the rising edge of CLK. |
| LD\# | 27 | 1 | Asynchronous load pin. LD\# is used to load the delay control registers. The delay control word is loaded serially from LSB to MSB. This signal drives the clock input to a 15-bit serial shift register. Each LD\# cycle, the data is transferred through the register bank on the rising edge of LD\# In order to load the delay control word, the user must supply exactly 15 LD\# puises. |
| DEL | 26 | I | Delay input. This is the serial input data that is sampled by the rising edge of LD\#. It is the input to the first stage of the 15 -bit serial shift register which contains the delay control word. Synchronous to the rising edge of LD\#. |
| BYPASS | 61 | 1 | Allows user to disable (bypass) the LD\# interface and use the default delay paths. When BYPASS $=1$, the delay control word is forced to all 0's and no extra delays are included in the paths. When BYPASS $=0$, the delay control word must be initialized using the LD\#/DEL interface in order for the chip to give predictable results. This pin is asynchronous and is not intended to change states during operation. |
| DOUTO-12 | $\begin{aligned} & 59-56 \\ & 54-53 \\ & 51-50 \\ & 48-44 \end{aligned}$ | 0 | Output data bus. The data on this bus reflects the results of the equation: $2 x[A x M+B x(1-M)]$. The number format of the output is either 2's complement or unsigned depending on the value of the TC\# signal during data input. The representation of DOUT is also dependent on the value sampled on RND0-1 during data input. (See RND0-1 \& TC\# pin description) |
| OE\# | 60 | 1 | Output enable. Asynchronous input which takes effect immediately following a transition. When OE\# = 0 the DOUT bus is driving, when OE\# = 1 the DOUT bus is not driven (floating). |
| $\mathrm{V}_{\mathrm{cc}}$ | 32,49,66 | 1 | 5 V power supply. There are $3 \mathrm{~V}_{\mathrm{CC}}$ pads. |
| GND | 16,39,55 | 1 | OV power supply. There are 3 GND pads. |

## Functional Block Diagram



FIGURE 1. FUNCTIONAL BLOCK DIAGRAM

## Functional Description

The Digital Video Mixer is intended for use in professional video, multimedia and medical imaging applications. The HSP48212 allows the user to mix two video sources based on a programmable weighting factor. After weighting the input data signals, the Video Mixer simply adds the two weighted signals mathematically. This results in the mixed output, which is a weighted sum of the two sources. The fundamental equation implemented by this architecture is:

Eq. (1) DOUT $=2 \times$ [DINA $\times M+$ DINB $\times(1-M)]$
where DINA and DINB are the two video sources (pixels) and $M$ is the weighting (Mix) factor. As expressed by this equation, the output DOUT is a weighted average of the incoming pixels. For instance, when $M$ is set to 0 the DINB input source is passed to the output, and when $M$ is set to 1 the DINA input is passed to the output, and when $M$ is set to 0.5 the output is the sum of the two sources DINA and DINB. The user can therefore vary the mix factor to apply different weights to each of the inputs DINA, DINB. This allows functions such as fading in, fading out, fading between images, graphics overlays, and keying. The multiplication factor of 2 as seen in Eq. (1) is accomplished through a 1-bit shift left (See Figure 1). This shifter is not programmable and cannot be accessed by the user.

The functional block diagram is shown in Figure 1. It can be seen that Eq. (1) is directly implemented by this architecture. The architecture has a 6 stage inherent latency. This architecture is extremely flexible in that it allows the user to account for misaligned input data by independently programming up to seven additional delay stages for DINAO-11, DINB0-11, and M0-11, as well as for the format control signals TC\# and RNDO-1. The programmable delay registers are controlled by the signals DEL, LD\#, and BYPASS.

The HSP48212 input interface is primarily synchronous to the rising edge of CLK with the exception of the programmable delay control signals DEL, LD\#, and BYPASS. The output data bus DOUTO-12 is registered synchronous to the rising edge of CLK and may also be controlled via the asynchronous output enable signal OE\#. The input data, DINAO-11 and DINB0-11, as well as the mix factor M0-11 have 12-bit precision. The output data DOUTO-12 has 13 -bit precision to allow for 1-bit of growth.

The signals TC\# and RNDO-1 control the format of the input and output data. TC\# allows DINAO-11 and DINB 0-11 to be either two's complement or unsigned (Note: DINAO-11 and DINB0-11 must have the same format, i.e. no mixed mode). The output data DOUTO-12 can be rounded to $8,10,12$, or 13-bits as determined by the control signals RNDO-1.

## Input Data Format

DINA0-11 and DINB0-11 represent two digital video sources (pixels). Each input bus has 12-bits of precision. They may be represented in two's complement form (TC\# = 0) or in unsigned form (TC\# = 1). It is important to note that DINAO11 and DINBO-11 must be represented in the same format (i.e. No mixed mode operation is allowed).

M0-11 supplies the weighting (Mix) factor and has 12-bits of precision. M0-11 must be represented in unsigned format and may range from 0 to 1 . If a value greater than 1 is placed on the bus, the internal circuitry will saturate MO-11 to 1.00000000000.

DINAO-11, DINBO-11, and M0-11 are synchronously registered on the rising edge of CLK.

The signal MIXEN allows the user to disable the internal clock signal which samples the M0-11 input bus. When MIXEN $=0$, the M0-11 bus is ignored and the previously sampled M0-11 value is used. When MIXEN = 1 , the M0-11 bus is sampled on the rising edge of CLK.

## Programmable Delay

The input data (DINAO-11, DINBO-11), mix factor (M0-11), and control signals (RND0-1, TC\#), may be delayed relative to each other in order to compensate for any misalignment that may have occurred prior to entering the HSP48212. Each input's delay may be independently programmed for up to seven delays. In other words, the user can program a different number of pipeline delays for each input. This programmed delay is in addition to the inherent 6 stage delay required by the architecture.

As shown in Figures 2 and 3, the programmable delay information is loaded using the signals LD\# and DEL. LD\# is the asynchronous load pin used to clock in the delay control word. The delay control word is clocked into a 15 -bit serial shift register on the rising edge of LD\# (i.e. DEL is synchronous to LD\#). The delay control word data is supplied by the DEL signal beginning with the least significant bit and continuing until the most significant bit has been clocked in. On each LD\# cycle the DEL data input is transferred through the register bank. The user must supply exactly 15 LD\# pulses; if the shift register is clocked more than 15 times, only the most recent 15 data inputs will be stored.

As previously stated, the length of the control word is 15-bits: 3bits are allocated for each of the 5 inputs, DINAO-11, DINBO-11, MO-11, RNDO-1, and TC\#. Each 3-bits of the control word allow the user to specify from 0 to 7 additional delay stages by programming the binary equivalent of the desired delay into the appropriate bit position of the delay control word register (e.g. 000 for 0 delays, 001 for 1 delay, ..., 111 for 7 delays).

TABLE 1. DELAY CONTROL WORD

| INPUT SIGNAL | CONTROL WORD BIT POSITION |
| :---: | :---: |
| RND0-1 | $12-14$ |
| TC\# | $9-11$ |
| MO-11 | $6-8 y$ |
| DINB0-11 | $3-5$ |
| DINA0-11 | $0-2$ |

The BYPASS control signal enables the programmable delay registers to be bypassed. When BYPASS is high, the delay control word is forced to all O's and no additional delays are included in any of the input paths. However, when BYPASS is low, the LD\#/DEL serial delay control word interface is active and the delay control word must be initialized in order to achieve any meaningful results.


FIGURE 2. DELAY CONTROL WORD SHIFT REGISTER

## Fórmâa Cúntrố Siguináís

The control signals TCH and RNDO-1 are used to specify the input data representation and the output data representation respectively. TC" and RNDO-1 are synchronous to CLK, which allows them to be changed on a cycle by cycle basis if needed. The control signals are designed to match the latency of the data paths. When the control inputs change,
the new configuration will effect the current input data and will not effect the data in the pipeline stages. For example, if the rounding selection is changed from 8 -bit rounding to 10 bit rounding on a given cycle, the output will remain in an 8bit representation while the new data is propagating through the circuit. When the results of the new data are available at the output, the number format will change to 10-bits.
The RND0-1 control signals determine the number of significant bits on the output bus DOUTO-12. The output data may be rounded to $8,10,12$, or 13 -bits. The rounding operation is performed by adding a binary 1 to the bit position right of the desired LSB and forcing the undesired bits to 0 . For example, in 8 -bit rounding, a 1 is added to the 9 th bit to the right of the MSB (DOUT4), and DOUT0-4 are forced to 0 (i.e. DOUTO-12 = XXXXXXXX00000).

## Output Control

DOUTO-12 is the output data bus which represents the weighted average of the incoming pixel data as indicated by Eq. (2):
Eq. (2) DOUT $=2 \times[($ DINA $\times M)+($ DINB $\times(1-M))]$
The output data will be represented in either two's complement format or in unsigned format depending on the value of the TC\# signal when the input data (DINAO-11 and DINBO11) is sampled by CLK. Similarly, the output representation of DOUTO-12 is also dependent on the value of RND0-1 during sampling of the input data.

The output data DOUTO-12 is registered at the output of the HSP48212 on the rising edge of CLK. The output data may be accessed through the activation of the signal OE\#. OE\# is an asynchronous input which, when low, causes the DOUT0-12 bus to drive; when OE\# is high, the DOUT0-12 bus is not driven (floating).

DEL


FIGURE 3. DELAY CONTROL WORD TIMING DIAGRAM

## Absolute Maximum Ratings

| Supply Voltage | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| :---: | :---: | :---: |
| Input, Output or I/O Voltage | $43^{\circ} \mathrm{C} / \mathrm{W}$ | $15^{\circ} \mathrm{C} / \mathrm{W}$ |
| Storage Temperature Range | $51^{\circ} \mathrm{C} / \mathrm{W}$ | $30^{\circ} \mathrm{CN}$ |
| Junction Temperature . | Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ |  |
| Lead Temperature (Soldering 10s) |  | 1.86W |
| ESD Classification |  | .1.57W |
|  |  | , 000 Gates |

## Operating Conditions

Operating Voltage Range, Commercial $.+5 \mathrm{~V} \pm 5 \%$
Operating Temperature Range, Commercial $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## DC Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {ccop }}$ | Power Supply Current | - | 170 | mA | $V_{C C}=$ Max, CLK Frequency 40 Mhz , Note 2, Note 3 |
| $I_{\text {ccss }}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=$ Max, Outputs Not Loaded |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {cc }}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | $\checkmark$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage | - | 0.8 | V | $V_{C C}=M i n$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\mathrm{cc}}=$ Max |
| $\mathrm{V}_{\text {ILC }}$ | Clock input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{cc}}=\mathrm{Min}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | - | 10 | pF | CLK Frequency 1 MHz , All Measurements Referenced to GND. |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | - | 10 | pF | $T_{A}=+25^{\circ} \mathrm{C}, \text { Note } 1$ |

NOTES:

1. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
2. Power Supply current is proportional to operating frequency. Typical rating for $I_{\text {ccop }}$ is 4.25 mAMHz .
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.

## AC Electrical Specifications

| SYMBOL | PARAMETER | 40MHz |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| $\mathrm{T}_{\text {cP }}$ | CLK Period | 25 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | CLK High | 10 | - | ns |
| $T_{C L}$ | CLK Low | 10 | - | ns |
| $\mathrm{T}_{\text {LP }}$ | LD\# Period | 25 | - | ns |

## AC Electrical Specifications

| SYMBOL | PARAMETER | 40MHz |  | UNITS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| $\mathrm{T}_{\text {LH }}$ | LD\# High | 10 | - | ns |
| $\mathrm{T}_{\mathrm{LL}}$ | LD\# Low | 10 | $\bullet$ | ns |
| TDS | Data Setup Time to CLK High | 10 |  | ns |
| $\mathrm{T}_{\mathrm{DH}}$ | Data Hold Time from CLK High | 0 | - | ns |
| $\mathrm{T}_{\text {MS }}$ | MIX Data Setup Time to CLK High | 10 | $\bullet$ | ns |
| $\mathrm{T}_{\text {M }}$ | MIX Data Hold Time From CLK High | 0 | - | ns |
| Tcs | Control Data Setup Time to CLK High | 10 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | Control Data Hold Time From CLK High | 0 | - | ns |
| $\mathrm{T}_{\mathrm{DLS}}$ | DEL Setup to LD\# High | 12 | - | ns |
| $\mathrm{T}_{\mathrm{DLH}}$ | DEL Hold from LD* High | 0 | - | ns |
| Tout | CLK to Output Data Delay | - | 13 | ns |
| ToE | Output Enable Time | - | 13 | ns |
| TOD | Output Disable Time | $\bullet$ | 13 | ns, Note 2 |
| $\mathrm{T}_{\mathrm{Mr}}$ |  | - | 5 | ns. Note 2 |

NOTES:

1. AC tests performed with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}, \mathrm{l}_{\mathrm{LL}}=2 \mathrm{~mA}$, and $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$. Input reference level $C L K=2.0 \mathrm{~V}$. Input reference level for all other inputs is 1.5 V . Test $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{HC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{ILC}}=0 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or Design changes.

## AC Test Load Circuit




HSP48410

## Features

- 10-Bit Pixel Data
- 4k $\times 4 \mathrm{k}$ Frame Sizes
- Asynchronous Flash Clear Pin
- Single Cycle Memory Clear
- Fully Asynchronous 16 or 24-Bit Host Interface
- Generates and Stores Cumulative Distribution Function
- Look Up Table Mode
- $1024 \times 24$-Bit Delay Memory
- 24-Bit Three State VO Bus
- DC to 40MHz Clock Rate


## Applications

- Histogramming
- Histogram Equalization
- Image and Signal Analysis
- Image Enhancement
- RGB Video Delay Line


## Description

The Harris HSP48410 is an 84 lead Histogrammer IC intended for use in image and signal analysis. The on-board memory is configured as $1024 \times 24$ array. This translates to a pixel resolution of 10-bits and an image size of $4 \mathrm{k} \times 4 \mathrm{k}$ with no possibility of overflow.

In addition to Histogramming, the HSP48410 can generate and store the Cumulative Distribution Function for use in Histogram Equalization applications. Other capabilities of the HSP48410 include: Bin Accumulation, Look Up Table, 24-bit Delay memory, and Delay and Subtract mode.

A Flash Clear pin is available in all modes of operation and performs a single cycle reset on all locations of the internal memory array and all internal data paths.

The HSP48410 includes a fully asynchronous interface which provides a means for communications with a host, such as a microprocessor. The interface includes dedicated Read/Write pins and an address port which are asynchronous to the system clock. This allows random access of the Histogram Memory Array for analysis or conditioning of the stored data.

Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :--- | :--- |
| HSP48410JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP48410JC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP48410GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP48410GC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |

Block Diagram


## Pinouts



PIN

Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CLK | 1 | 1 | Clock input. This input has no effect on the chips functionality when the chip is programmed to an asynchronous mode. All signals denoted as synchronous have their timing specified with reference to this signal. |
| PINO-9 | 3-11, 83 | 1 | Pixel Input. This input bus is sampled by the rising edge of clock. It provides the onchip RAM with address values in Histogram, Bin Accumulate and LUT(write) mode. During Asynchronous modes it is unused. |
| LD\# | 15 | 1 | The Load pin is used to load the FCTO-2-bits into the FCT registers. (See below). |
| FCTO-2 | 16-18 | 1 | These three pins are decoded to determine the mode of operation for the chip. The signals are sampled by the rising edge of LD\# and take effect after the rising edge of LD". Since the loading of this function is asynchronous to CLK, it is necessary to disable the START\# pin during loading and enable START\# at least 1 CLK cycle following the LD\# pulse. |
| START\# | 14 | 1 | This pin informs the on-chip circuitry which clock cycle will start and/or stop the current mode of operation. Thus, the modes are asynchronously selected (via LD\#) but are synchronously started and stopped. This input is sampled by the rising edge of CLK. The actual function of this input depends on the mode that is selected. START\# must always be held high (disabled) when changing modes. This will provide a smooth transition from one mode to the next by allowing the part to reconfigure itself before a new mode begins. When START\# is high, LUT(read) mode is enabled except for Delay and Delay and Subtract modes. |
| FC\# | 12 | 1 | Flash Clear. This input provides a fully asynchronous signal which effectively resets all bits in the RAM Array and the input and output data paths to zero. |
| U̇iviû-żs | 5б- 65-82 | 1 | Uata input bus. Provides data to the Histogrammer during Bin Accumulate, LUT, Delay and Delay and Subtract modes. Synchronous to CLK. |
| DIO0-23 | $\begin{aligned} & 33-40, \\ & 42-57 \end{aligned}$ | I/O | Asynchronous data bus. Provides RAM access for a microprocessor in preconditioning the memory array and reading the results of the previous operation. Configuarable as either a 24 or 16-bit bus. |
| IOADDO-9 | 22-31 | 1 | RAM address in asynchronous modes. Sampled on the falling edge of WR\# or RD\#. |
| Uws | 21 | 1 | Upper Word Select. In 16-bit Asynchronous mode, a one on this pin denotes the contents of DIOO-7 as being the upper eight-bits of the data in or out of the Histogrammer. A zero means that DIO0-15 are the lower 16-bits. In all other modes, this pin has no effect. |
| WR\# | 19 | 1 | Write enable to the RAM for the data on DIO0-23 when the HSP48410 is configured in one of the asynchronous modes. Asynchronous to CLK. |
| RD* | 13 | 1 | Read control for the data on DIO0-23 in asynchronous modes. Output enable for DIO0-23 in other modes. Asynchronous to CLK. |
| $V_{c c}$ | 2,32 |  | $+5 \mathrm{~V} .0 .1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | 20, 41, 64, 84 |  | Ground |

NOTES:

1. A \# after a pin name denotes an active low signal.
2. Bit 0 is the LSB on all busses.

## Functional Description

The Histogrammer is intended for use in signal and image processing applications. The on-board RAM is 24-bits by 1024 locations. For histogramming, this translates to an image size of $4 \mathrm{k} \times 4 \mathrm{k}$ with 10-bit data. A functional block diagram of the part is shown in Figure 1.

In addition to histogramming, the HSP48410 will also perform Histogram Accumulation while feeding the results back into the memory array. The on-board RAM will then contain the Cumulative Distribution Function and can be used for further operation such as histogram equalization.

Other modes are: Bin Accumulate, Look Up Table (LUT), Delay Memory, and Delay and Subtract. The part can also be accessed as a 24 -bit by 1024 word asynchronous RAM for preconditioning or reading the results of the histogram.

The Histogrammer can be accessed both synchronously and asynchronously to the system clock (CLK). It was designed to be configured asynchronously by a microprocessor, then switched to a synchronous mode to process data. The result of the processing can then be read out synchronously, or the part can be switched to one of the asynchronous modes so the data may be read out by a microprocessor. All modes are synchronous except for the Asynchronous 16 and 24 modes.
A Flash Clear operation allows the user to reset the entire RAM array and all input and output data paths in a single cycle.

## Histogram Memory Array

The Histogram Memory Array is a 24-bit by 1024 deep RAM. Depending on the current mode, its input data comes from either the synchronous input DINO-23, from the asynchronous data bus DIOO-23, or from the output of the adder. The output data goes to the DIO bus in both synchronous and asynchronous modes.

## Address Generator

This section of the circuit determines the source of the RAM address. In the synchronous modes, the address is taken from either the output of the counter or PINO-9. The pixel input bus is used for Histogram, Bin Accumulate, and LUT(read) modes. All other synchronous modes, i.e. Histogram Accumulate, LUT(write), Delay, and Delay and Subtract use the counter output. The counter is reset on the first rising edge of CLK after a falling edge on START\#.

During asynchronous modes, the read and write addresses to the RAM are taken from the IOADD bus on the falling edge of the RD\# and WR\# signals, respectively.

## Adder Input

The Adder Input Control section contains muxes, registers and other logic that provide the proper data to the adder. The configuration of this section is controlled by the output of the Function Decode section.

## DIO Interface

The DIO Interface Section transfers data between the Histogrammer and the outside world. In the synchronous modes, DIO acts as a synchronous output for the data currently being processed by the chip; RD\# acts as the output enable for the DIO bus; WR\# and IOADDO-9 have no effect. When either of the Asynchronous modes are selected (16 or 24-bit), the RAM output is passed directly to the DIO bus on read cycles, and on write cycles, data input on DIO goes to the RAM input port. In this case, data reads and writes are controlled by RD\#, WR\# and IOADD0-9.

## Function Decode

This section provides the signals needed to configure the part for the different modes. The eight modes are decoded from FCTO-2 on the rising edge of LD\# (see Table 1). The output of this section is a set of signals which control the path of data through the part.

The mode should only be changed while START\# is high. After changing from one mode to another, START\# must be clocked high by the rising edge of CLK at least once.

TABLE 1. FUNCTION DECODE

| FCT |  |  |  |
| :---: | :---: | :---: | :--- |
| 2 | 1 | 0 |  |
| 0 | 0 | 0 | Mistogram |
| 0 | 0 | 1 | Histogram Accumulate |
| 0 | 1 | 0 | Delay and Subtract |
| 0 | 1 | 1 | Look Up Table |
| 1 | 0 | 0 | Bin Accumulate |
| 1 | 0 | 1 | Delay Memory |
| 1 | 1 | 0 | Asynchronous 24 |
| 1 | 1 | 1 | Asynchronous 16 |

## Flash Clear

Flash Clear allows the user to clear the entire RAM with a single pin. When the FC\# pin is low, all bits of the RAM and the data path from the RAM to DIOO-23 are set to zero. The FC\# pin is asynchronous with respect to CLK: the reset begins immediately following a low on this signal. For synchronous modes, in order to ensure consistent results, FC\# should only be active while START\# is high. For asynchronous modes, WR\# must remain inactive while FC\# is low.

Functional Block Diagram


ALL REGISTERS ARE CLOCKED BY CLK
FIGURE 1. FUNCTIONAL BLOCK DIAGRAM

## Histogram Mode

This is the fundamental operation for which this chip was intended. When this mode is selected, the chip configures itself as shown in the block diagram of Figure 2. The pixel data is sampled on the rising edge of clock and used as the read address to the RAM array. The data contained in that address (or bin) is then incremented by 1 and written back into the RAM at the same address.


FIGURE 2. HISTOGRAM MODE BLOCK DIAGRAM

At the same time, the new value is also displayed on the DIO bus. This procedure continues until the circuit is interrupted by START\# returning high. When START\# is high, the RAM write is disabled, the read address is taken from the Pixel Input bus, and the chip acts as if it is in LUT(read) mode. Figure 3 shows histogram mode timing. START\# is used to disregard the data on PINO-9 at DATA2. START\# is sampled on the rising edge of clock, but is delayed internally by 3 cycles to match the latency of the Address Generator. Data is clocked onto the DIO bus on the rising edge of CLK. RD\# acts as output enable.


FIGURE 3. HISTOGRAM MODE TIMING

## Histogram Accumulate Mode

This function is very similar to the Histogram function. In this case, a counter is used to provide the address data to the RAM. The RAM is sequentially accessed, and the data from each bin is added to the data from the previous bins. This accumulation of data continues until the function is halted. The results of the accumulation are displayed on the DIO bus while simultaneously being written back to the RAM. When the operation is complete, the RAM will contain the Cumulative Distribution Function (CDF) of the image.

Figure 4 shows the configuration for this mode. Once this function is selected, the START\# pin is used to reset the counter and enable writing to the RAM. Write enable is delayed 3 cycles to match the delay in the Address Generator. The START\# pin determines when the accumulation will begin. Before this pin is activated, the counter will be in an unknown state and the DIO bus will contain unpredictable data. Once the START\# pin is sampled low, the data registers are reset in order to clear the accumulation. The output (DIO bus) will then be zero until a non-zero data value is read from the RAM. Timing for this operation is shown in Figure 5.


FIGURE 4. HISTOGRAM ACCUMULATE MODE BLOCK DIAGRAM


FIGURE 5. HISTOGRAM ACCUMULATE MODE TIMING
The START\# pin must remain low in order to allow the accumulated data to overwrite the original histogram data contained in the RAM. When the START\# pin returns to a high state, the configuration remains intact, but writing to the RAM is disabled and the part is in LUT(read) mode. Note RAM is disabled and the part is in LUT(read) mode. Note
that the counter is not reset at this point. The counter will be reset on the first cycle of CLK that START\# is detected low. To prevent invalid data from being written to the RAM, when the counter reaches its maximum value (1023), further writing to the RAM is disabled and the counter remains at this value until the mode is changed.

At the end of the histogram accumulation, the DIO output bus will contain the last accumulated value. The chip will remain in this state until START\# becomes inactive. The results of the accumulation can then be read out synchronously by keeping START\# high, or asynchronously in either of the asynchronous modes.

## Bin Accumulate Mode

The functionality of this mode is also similar to the Histogram function. The only difference is that instead of incrementing the bin data by 1 , the bin data is added to the incoming DIN bus data. The DIN bus is delayed internally by 3 cycles to match the latency in the address generator. Figure 6 shows the block diagram of the internal configuration for this mode, while the timing is given in Figure 7. Note that in this figure, START\# is used to disregard the data on DINO-23 during DATA2.


FIGURE 6. BIN ACCUMULATE BLOCK DIAGRAM


FIGURE 7. BIN ACCUMULATE TIMING

## Look Up Table Mode

A Look Up Table (LUT) is used to perform a fixed transformation function on pixel values. This is particularly useful when the transformation is non-linear and cannot be realized directly with hardware. An example is the remapping of the original pixel values to a new set of values based on the CDF obtained through Histogram Accumulation.
The transformation function can be loaded into the LUT in one of three ways: in LUT mode, through DINO-23; in either asynchronous mode, over the DIO bus as described below under Asynchronous 16/24 Modes; in the Histogram Accumulate mode the transiormation function is calculated internally (see description above). The transformation function can then be utilized by deactivating START\#, putting the part in LUT mode and clocking the data to be transformed onto the PIN bus. Note that it is necessary to wait one clock cycle after changing the mode before clocking data into the part.

The block diagram and timing for this mode are shown in Figures 8 and 9 . The left half of the timing diagram shows LUT(write) mode. On the first CLK that detects START\# low, the counter is reset and the write enable is activated for the RAM. As long as START\# remains low, the counter provides the write address to the RAM and data is sequentially loaded through the DIN bus. The DIN bus is delayed internally by 3 cycles to match the latency in the Address Generator. The DIO bus will contain the previous contents of the memory location beini upuateú. Whtien i024 wüuls liave deeri writien to the RAM, the counter stops and further writes to the RAM are disabled. The part stays in this state while START\# remains low.

When START\# returns high, the RAM write is disabled, the read address is taken from the PIN bus, and the chip acts as a synchronous LUT. (This is known as LUT(read) mode.) In order to ensure that the internal pipelines are clear, data should not be input to PINO-9 until the third clock after START\# goes high.


FIGURE 8. LOOK UP TABLE BLOCK DIAGRAM


* PREVIOUS CONTENTS OF BIN LOCATION. FIGURE 9. LOOK UP TABLE MODE TIMING


## Delay Memory (Row Buffer) Mode

As seen by comparing Figures 8 and 10, the configuration for this mode is nearly identical to the LUT mode. In this mode, however, the counter is always providing the address and the write function is always enabled.

In order to force this configuration to act as a row delay register, the START\# signal must be used to reset the internal counter each time a new row of pixels is being sampled. Because of the inherent latency in the address and data paths, the counter must be reset every N-4 cycles, where N is the desired delay length. For example, if a delay from DIN to DIO of ten cycles is desired, the START\# signal must be set low every six cycles (see Figure 11). If the internal address counter reaches its maximum count (1023), it holds that value and further writes to the RAM are disabled.


FIGURE 10. DELAY MEMORY BLOCK DIAGRAM


FIGURE 11. DELAY MEMORY MODE TIMING FOR ROW LENGTH OF TEN

## Delay and Subtract Mode

This mode is similar to the Delay Memory mode, except the input data is subtracted from the corresponding data stored in RAM (See Figures 12 and 13).


FIGURE 12. DELAY AND SUBTRACT BLOCK DIAGRAM


FIGURE 13. DELAY AND SUBTRACT MODE TIMING FOR ROW LENGTH OF TEN

## Asynchronous 16/24 Modes

In the Asynchronous modes, the chip acts like a single port RAM. In this mode, the user can read (access) any bin location on the fly by simply setting the 10-bit IO address to the desired bin location. The RAM is then read or written on the following RD\# or WR\# pulse. A block diagram for this mode is shown in Figure 14. Note that all registers and pipeline stages are bypassed; START\# and CLK have no effect in this mode.

Timing waveforms for this mode are also shown in Figure 15. During reading, the read address is latched (internally) on the falling edge of RD\#. During write operations, the address is latched on the falling edge of WR\# and data is latched on the rising edge of WR\#. Note that reading and writing occur on different ports, so that, in this mode, the write port always latches its address and data values from the WR\# signal, while the read port always uses RD\# for latching.

The difference between the Async 16 mode and the Async 24 mode is the number of data bits available to the user. In 16-bit mode, the user can connect the system data bus to the lower 16 -bits of the Histogrammer's DIO bus. The UWS pin becomes the LSB of the IO address, which determines if the lower 16-bits or upper 8-bits of the 24-bit Histogrammer data is being used. When UWS is low, the data present at DIO0-15 is the lower 16-bits of the data in the IOADD0-9 location. When UWS is high, the upper 8-bits of the IOADD09 location are present on DIO0-7. (This is true for both reading and writing.) Thus it takes 2 cycles for an asynchronous 24-bit operation when in Async 16 mode. Unused outputs are zeros.


FIGURE 14. ASYNCHRONOUS 16/24 BLOCK DIAGRAM
write cycle timing

READ CYCLE TIMING

FIGURE 15. ASYNCHRONOUS 16/24 MODE TIMING


## Absolute Maximum Ratings



## Thermal Information



PLCC Package $23.0^{\circ} \mathrm{C}$ N $7.4^{\circ} \mathrm{CM}$ Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$

PGA Package
3.1W

PLCC Package . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.5W
Gate Count .3500 Gates

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions



## DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{C C}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{Cc}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\mathrm{HC}}$ | 3.0 | $\bullet$ | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | IL | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| In Leakage Current | ! | -10 | 10 | $\mu \mathrm{A}$ | $V_{\text {OUI }}=V_{\text {CC }}$ of GAND, $V_{\text {cc }}-5.25 V^{\prime}$ |
| Standby Supply Current | $I_{\text {ccse }}$ | - | 500 | $\mu \mathrm{A}$ | $V_{I N}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V}$ Outputs Open |
| Operating Power Supply Current | Iccop | - | 396 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}(\text { Note } 1,2) \end{aligned}$ |

NOTES:

1. Power supply current is proportional to operating frequency. typical rating for $\mathrm{I}_{\mathrm{ccop}}$ is 12 mAMHz .
2. Maximum junction temperature must be considered when operating part at high clock frequencies.

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Not tested, but characterized at initial design and at major process or design changes.

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all <br> measurements are referenced to <br> device ground. |
| Output Capacitance | C $_{\text {OUT }}$ | - | 12 | pF |  |

AC Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| PARAMETER | SYMBOL | -40 ( 40 MHz ) |  | -33 (33 MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | $\mathrm{T}_{\text {CP }}$ | 25 | - | 30 | - | ns |  |
| Clock Low | $\mathrm{T}_{\mathrm{CH}}$ | 10 | - | 12 | - | ns |  |
| Clock High | $\mathrm{T}_{\mathrm{CL}}$ | 10 | - | 12 | - | ns |  |
| DIN Setup | $\mathrm{T}_{\mathrm{DS}}$ | 12 | - | 13 | - | ns |  |

Specifications HSP48410
AC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1) (Continued)

| PARAMETER | SYMBOL | -40 (40 MHz) |  | -33 (33 MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| DINO-23 Hold | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | 0 | - | ns |  |
| Clock to DIOO-23 Valid | $T_{D}$ | - | 15 | - | 19 | ns |  |
| FC\# Pulse Width | $\mathrm{T}_{\mathrm{FL}}$ | 35 | - | 35 | - | ns |  |
| FCTO-2 Setup to LD\# | TFS | 10 | - | 10 | - | ns |  |
| FCT0-2 Hold from LD\# | $\mathrm{T}_{\mathrm{FH}}$ | 0 | - | 0 | - | ns |  |
| START\# Setup to CLK | $\mathrm{T}_{\text {SS }}$ | 12 | - | 13 | - | ns |  |
| START\# Hold from CLK | $\mathrm{T}_{\text {SH }}$ | 0 | - | 0 | - | ns |  |
| PIN0-9 Setup Time | $\mathrm{T}_{\mathrm{PS}}$ | 12 | - | 13 | - | ns |  |
| PINO-9 Hold Time | $\mathrm{T}_{\mathrm{PH}}$ | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | $\mathrm{T}_{L 1}$ | 10 | - | 12 | - | ns |  |
| LD\# Setup to START\# | TLS | TCP |  | $\mathrm{T}_{\mathrm{CP}}$ | - | ns | Note 2 |
| WR\# Low | $T_{\text {WL }}$ | 12 | - | 15 | - | ns |  |
| WR\# High | TWH | 12 | - | 15 | - | ns |  |
| Address Setup | $\mathrm{T}_{\text {AS }}$ | 13 | - | 15 | - | ns |  |
| Address Hold | $\mathrm{T}_{\text {AH }}$ | 1 | - | 1 | - | ns |  |
| DIO Setup to WR\# | Tws | 12 | - | 15 | - | ns |  |
| DIO Hold from WR\# | $\mathrm{T}_{\text {WH }}$ | 1 | - | 1 | - | ns |  |
| RD\# Low | $\mathrm{T}_{\mathrm{RL}}$ | 35 | - | 43 | - | ns |  |
| RD\# High | TRH | 15 | - | 17 | - | ns |  |
| RD\# Low to DIO Valid | $\mathrm{T}_{\mathrm{RD}}$ | - | 35 | - | 43 | ns |  |
| ReadWrite Cycle Time | $T_{C Y}$ | 55 | - | 65 | - | ns |  |
| DIO Valid after RD\# High | $\mathrm{T}_{\mathrm{OH}}$ | - | 0 | - | 0 | ns | Note 3 |
| Output Enable Time | TOE | - | 18 | - | 19 | ns | Note 4 |
| Output Disable Time | $\mathrm{T}_{\mathrm{OD}}$ | - | 18 | - | 19 | ns | Note 3 |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 6 | - | 6 | ns | From 0.8V to 2.0 V , Note 3 |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 6 | - | 6 | ns | From 2.0 V to 0.8 V , Note 3 |

## NOTES:

1. AC Testing is performed as follows: Input levels (CLK) 0.0 V and 4.0 V ; Input levels (All other inputs) 0 V and 3.0 V . Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (All others) $=1.5 \mathrm{~V}$. Output load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. There must be at least one rising edge of CLK between the rising edge of LD\# and the falling edge of START\#.
3. Characterized upon initial design and after major changes to design and/or process.
4. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $C_{L}=40 \mathrm{pF}$.

## Test Load Circuit



## Waveforms



## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- 10-Bit Pixel Data
- 4k x 4k Frame Sizes
- Asynchronous Flash Clear Pin
- Fully Asynchronous 16-Bit or 24-Bit Host Interface
- DC to 33MHz Clock Rate


## Applications

- Histogramming
- Histogram Equalization
- Image and Signal Analysis

Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP48410GM-33/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP48410GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The Harris HSP48410 is an 84 lead Histogrammer IC intended for use in image and signal analysis. The on board memory is configured as $1024 \times 24$ array. This translates to a pixel resolution of 10 -bits and an image size of $4 \mathrm{k} \times 4 \mathrm{k}$ with no possibility of overflow.
In addition to Histogramming, the HSP48410 can generate and store the Cumulative Distribution Function for use in Histogram Equalization applications. Other capabilities of the HSP48410 include: Bin Accumulation, Look Up Table, 24-bit Delay memory, and Delay and Subtract mode.

A Fiash Clear pin is available in all modes of operation and performs a single cycle reset on all locations of the internal memory array and all internal data paths.

The HSP48410 includes a fully asynchronous interface which provides a means for communications with a host, such as a microprocessor. The interface includes dedicated Read/Write pins and an address port which are asynchronous to the system clock. This allows random access of the Histogram Memory Array for analysis or conditioning of the stored data.

## Block Diagram



HSP48410/883


Pin Description

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CLK | C6 | 1 | Clock input. This input has no effect on the chips functionality when the chip is programmed to an asynchronous mode. All signals denoted as synchronous have their timing specified with reference to this signal. |
| PINO-9 | A1-5, A7, B3-5, C5 | 1 | Pixel Input. This input bus is sampled by the rising edge of clock. It provides the on chip RAM with address values in Histogram, Bin Accumulate and LUT(write) mode. During Asynchronous modes it is unused. |
| LD\# | C1 | 1 | The Load pin is used to load the FCTO-2 bits into the FCT registers. (See below). |
| FCTO-2 | D1-2, E3 | 1 | These three pins are decoded to determine the mode of operation for the chip. The signals are sampled by the rising edge of LD\# and take effect after the rising edge of LD\#. Since the loading of this function is asynchronous to CLK, it is necessary to disable the START\# pin during loading and enable START\# at least 1 CLK cycle foliowing the LD\# pulse. |
| START\# | B1 | 1 | This pin informs the on chip circuitry which clock cycle will start and/or stop the current mode of operation. Thus, the modes are asynchronously selected (via LD\#) but are synchronously started and stopped. This input is sampled by the rising edge of CLK. The actual function of this input depends on the mode that is selected. START\# must always be held high (disabled) when changing modes. This will provide a smooth transition from one mode to the next by allowing the part to reconfigure itself before new mode begins. When START\# is high, LUT(read) mode is enabled except for Delay and Delay and Subtract modes. |
| FC\# | B2 | 1 | Flash Clear. This input provides a fully asynchronous signal which effectively resets all bits in the RAM Array and the input and output data paths to zero. |
| DINO-23 | $\begin{aligned} & \text { A8-11, B6-11, } \\ & \text { C10-11, D10-11, } \\ & \text { E9-11, F10-11, } \\ & \text { G9-11, H10-11 } \end{aligned}$ | 1 | Data input bus. Provides data to the Histogrammer during Bin Accumulate, LUT, Delay and Delay and Subtract modes. Synchronous to CLK. |
| DIOO-23 | $\begin{aligned} & \text { J5-7, J10-11, } \\ & \text { K2-11, L2-4, L6-11 } \end{aligned}$ | I/O | Asynchronous data bus. Provides RAM access for a microprocessor in preconditioning the memory array and reading the results of the previous operation. Configuarable as either a 24 -bit or 16 -bit bus |
| IOADD0-9 | $\begin{aligned} & \text { F1,F3,G1-3, H1-2, } \\ & J 1-2, K 1 \end{aligned}$ | 1 | RAM address in asynchronous modes. Sampled on the falling edge of WR\# or RD\#. |
| UWS | F2 | 1 | Upper Word Select. In 16-bit Asynchronous mode, a one on this pin denotes the contents of DIO0-7 as being the upper eight-bits of the data in or out of the Histogrammer. A zero means that DIOO-15 are the lower 16-bits. In all other modes, this pin has no effect. |
| WR\# | E2 | 1 | Write enable to the RAM for the data on DIO0-23 when the HSP48410 is configured in one of the asynchronous modes. Asynchronous to CLK. |
| RD\# | C2 | 1 | Read control for the data on DIO0-23 in asynchronous modes. Output enable for DIOO-23 in other modes. Asynchronous to CLK. |
| VCC | A6, L1 |  | $+5 \mathrm{~V}$ |
| GND | C7, E1, F9, L5 |  | Ground |


#### Abstract

Absolute Maximum Ratings Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8.0 V Input, Output Voltage . . . . . . . . . . . . . . . . . . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ Storage Temperature . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering 10s). . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$ ESD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1

\section*{Reliability Information}

Thermal Resistance ........................ $\theta_{J A} \quad \theta_{J C}$ Ceramic PGA Package . . . . . . . . . . . . . . $34.3^{\circ} \mathrm{C}$ W $8.0^{\circ} \mathrm{C}$ W Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic PGA Package 1.46 Watt

Gate Count .3500 Gates

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.


## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. DC ELECTRICAL SPECIFICATIONS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $V_{1 H}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | $\bullet$ | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | $\checkmark$ |
| High Level Clock input | $\mathrm{V}_{\mathrm{HCO}}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 0.8 | V |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note 1 }) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output Low Voltage | V OL | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note 1 } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | $I_{L}$ | $\begin{aligned} & V_{i N}=V C C \text { or } G N D, \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | 10 | $\mu \mathrm{A}$ |
| I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND, } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $\cdot .55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | 10 | $\mu \mathrm{A}$ |
| Standby Supply Current | Iccss | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=25.6 \mathrm{MHz}, \\ & V_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}(\text { Note } 2) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 308 | mA |
| Functional Test | FT | ( Notes 3,4) | 7, 8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Power Supply current is proportional to operating frequency. Typical rating for $\mathrm{I}_{\mathrm{ccop}}$ is $12 \mathrm{~mA} / \mathrm{MHz}$. Maximum junction temperature must be considered when operating part at high clock frequencies.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.
4. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

## TABLE 2. AC ELECTRICAL PERFORMANCE CHARACTERISTICS

Device Tested at: $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Note 1)

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -33 (33MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | $\mathrm{T}_{\text {cP }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 39 | - | ns |
| Clock Low | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| Clock High | $\mathrm{T}_{\mathrm{CL}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| DIN Setup | $\mathrm{T}_{\mathrm{DS}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 16 | - | ns |
| DIN 0-23 Hold | $\mathrm{T}_{\mathrm{DH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Clock to DIO 0-23 Valid | $\mathrm{T}_{\mathrm{D}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 24 | ns |
| FC\# Pulse Width | $\mathrm{T}_{\mathrm{FL}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 35 | - | 35 | - | ns |
| FCT 0-2 Setup to LD\# | $\mathrm{T}_{\text {FS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| FCT 0-2 Hold from LD\# | $\mathrm{T}_{\text {FH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| START\# Setup to CLK | $\mathrm{T}_{\text {ss }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 16 | - | ns |
| START\# Hold from CLK | $\mathrm{T}_{\text {SH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| PIN 0-9 Setup Time | $\mathrm{T}_{\text {PS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 16 | - | ns |
| PIN 0-9 Hold Time | $\mathrm{T}_{\text {PH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| LD\# Pulse Width | $\mathrm{T}_{\mathrm{LL}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| LD\# Setup to START\# | $T_{\text {LS }}$ | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\mathrm{T}_{\mathrm{CP}}$ |  | $T_{\text {cP }}$ | - | ns |
| WR\# Low | $\mathrm{T}_{\mathrm{WL}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| WR\# High | $\mathrm{T}_{\text {WH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Address Setup | $\mathrm{T}_{\text {AS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 16 | - | 20 | - | ns |
| Address Hold | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| DIO Setup to WR\# | Tws |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | $\bullet$ | 20 | - | ns |
| DIO Hold from WR\# | $\mathrm{T}_{\text {WH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| RD\# Low | $\mathrm{T}_{\text {RL }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 43 | - | 55 | - | ns |
| RD\# High | $\mathrm{T}_{\text {RH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 20 | - | ns |
| RD\# Low to DIO Valid | TRO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 43 | - | 55 | ns |
| Output Enable Time | $\mathrm{T}_{\text {OE }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 24 | ns |
| Read/Write Cycle Time | $\mathrm{T}_{\mathrm{CY}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 65 |  | 80 | - | ns |

NOTES:

1. A.C. Testing is performed as follows: Input levels (CLK) 0.0 V and 4.0 V ; Input levels (All other inputs) 0 V and 3.0 V . Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (All others) $=1.5 \mathrm{~V}$. Output load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \geq 1.5 \mathrm{~V}$.
2. There must be at least one rising edge of CLK between the rising edge of LD\# and the falling edge of START\#.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

Specifications HSP48410/883

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -33 (33MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | $V_{\text {cc }}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$, All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ | $\mathrm{V}_{\mathrm{cc}}=\text { Open, } \mathrm{f}=1 \mathrm{MHz},$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| DIO Valid After RD\# High | $\mathrm{T}_{\mathrm{OH}}$ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | $\bullet$ | 0 | - | ns |
| Output Disable Time | Tod |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 27 | - | 27 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 9 | - | 9 | ns |
| Output Fall Time | $\mathrm{T}_{\text {F }}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 9 | - | 9 | ns |

NOTES:

1. Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples/5005 | $1,7,9$ |

## HSP48410/883

## Burn-In Circuits

84 LEAD GRID ARRAY
TOP VIEW


DIN 'At'

| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| A1 | PIN0 | F1 |
| A2 | PIN2 | F3 |
| A3 | PIN3 | F4 |
| A4 | PIN5 | F6 |
| A5 | PIN8 | F9 |
| A6 | VCC | VCC |
| A7 | PIN9 | F10 |
| A8 | DIN2 | F3 |
| A9 | DIN4 | F5 |
| A10 | DIN5 | F6 |
| A11 | DIN8 | F9 |
| B1 | START\# | F10 |
| B2 | FC\# | F16 |
| B3 | PIN1 | F2 |
| B4 | PIN4 | F5 |
| B5 | PIN7 | F8 |
| B6 | DIN1 | F2 |
| B7 | DIN0 | F1 |
| B8 | DIN3 | F4 |


| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| B9 | DIN6 | F7 |
| B10 | DIN7 | F8 |
| B11 | DIN10 | F11 |
| C1 | LD\# | F11 |
| C2 | RD\# | F1 |
| C5 | PIN6 | F7 |
| C6 | CLK | F0 |
| C7 | GND | GND |
| C10 | DIN9 | F10 |
| C11 | DIN11 | F12 |
| D1 | FCT1 | F13 |
| D2 | FCT2 | F14 |
| D10 | DIN12 | F13 |
| D11 | DIN13 | F14 |
| E1 | GND | GND |
| E2 | WR\# | F2 |
| E3 | FCT0 | F12 |
| E9 | DIN14 | F15 |
| E10 | DIN15 | F1 |


| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| E11 | DIN16 | F2 |
| F1 | IOADD5 | F6 |
| F2 | UWS | F11 |
| F3 | IOADD9 | F10 |
| F9 | GND | GND |
| F10 | DIN21 | F7 |
| F11 | DIN17 | F3 |
| G1 | IOADD7 | F8 |
| G2 | IOADD6 | F7 |
| G3 | IOADD8 | F9 |
| G9 | DIN18 | F4 |
| G10 | DIN20 | F6 |
| G11 | DIN19 | F5 |
| H1 | IOADD4 | F5 |
| H2 | IOADD3 | F4 |
| H10 | DIN23 | F9 |
| H11 | DIN22 | F8 |
| J1 | IOADD2 | F3 |
| J2 | IOADD0 | F1 |


| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| J5 | DIO6 | F7 |
| J6 | DIO9 | F10 |
| J7 | DIO10 | F11 |
| J10 | DIO21 | F7 |
| J11 | DIO23 | F9 |
| K1 | IOADD1 | F2 |
| K2 | DIO0 | F1 |
| K3 | DIO1 | F2 |
| K4 | DIO4 | F5 |
| K5 | DIO7 | F8 |
| K6 | DIO8 | F9 |
| K7 | DIO12 | F13 |
| K8 | DIO15 | F1 |
| K9 | DIO18 | F4 |
| K10 | DIO20 | F6 |
| K11 | DIO22 | F8 |
| L1 | VCC | VCC |
| L2 | DIO2 | F3 |
| L3 | DIO3 | F4 |
| L4 | DIO5 | F6 |

4. $0.1 \mu \mathrm{f}(\mathrm{min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $F_{O}=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots F 16=F 15 / 2$, 40\%-60\% Duty Cycle.
6. Input Voltage Limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max. $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Metallization Topology

DIE DIMENSIONS:
$330 \times 281 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or Si-Al-Cu
Thickness: 8k $\AA$
GLASSIVATION
Type: Nitrox
Thickness: 10kA
WORST CASE CURRENT DENSITY:
$0.47 \times 10^{5} \mathrm{~A}^{\mathrm{cm}}{ }^{2}$

## Metallization Mask Layout



$3 \times 3$ Image Filter

## Features

- DC to 30MHz Clock Rate
- Configurable for 1-D and 2-D Correlation/ Convolution
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- Two's Complement or Unsigned 8-Bit Input Data and Coefficients
- 20-Bit Extended Precision Output
- Standard $\mu$ P Interface


## Applications

- Image Filtering
- Edge Detection/Enhancement
- Pattern Matching
- Real Time Video Filters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP48901JC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP48901JC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP48901GC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP48901GC-30 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The Harris HSP48901 is a high speed 9-Tap FIR Filter which utilizes 8 -bit wide data and coefficients. It can be configured as a one dimensional (1-D) 9-Tap filter for a variety of signal processing applications, or as a two dimensional (2-D) filter for image processing. In the 2-D configuration, the device is ideally suited for implementing $3 \times 3$ kernel convolution. The 30 MHz clock rate allows a large number of image sizes to be processed within the required frame time for real-time video.

Data is provided to the HSP48901 through the use of programmable data buffers such as the HSP9500 or any other programmable shift register. Coefficient and pixel input data are 8 -bit signed or unsigned integers, and the 20 -bit extended output guarantees no overflow will occur during the filtering operation.
There are two internal register banks for storing independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data.
The configuration of the HSP48901 Image Filter is controlled through a standard microprocessor interface and all inputs and outputs are TTL compatible.

## Block Diagram



## Package Pinouts




## Pin Descriptions

| NAME | PLCC PIN | TYPE |  |
| :---: | :---: | :---: | :--- |
| VCC | $9,27,45,61$ |  | DESCRIPTION |
| GND | $18,29,38,56$ |  | The +5V power supply pins. O.1 $\mu$ F capacitors between the VCC and GND pins are <br> recommended. |
| CLK | 28 | I device ground. |  |

## Functional Description

The HSP48901 can perform convolution of a $3 \times 3$ filter kernel with 8-bit image data. It accepts the image data in a raster scan, non-interlaced format, convolves it with the filter kernel and outputs the filtered image. The input and filter kernel data are both 8 -bits, while the output data is 20 -bits to prevent overflow during the convolution operation. Image data is input via the DIN1, DIN2, and DIN3 busses. This data would normally be provided by programmable data buffer such as the HSP9501 as Illustrated in the operations section of this specification. The data is then convolved with the $3 \times 3$ array of filter coefficients. The resultant output data is then stored in the output register. The HSP48901 may also be used in a one-dimensional mode. In this configuration, it functions as a 1-D 9-tap FIR filter. Data would be input via the DIN1(0-7) bus for operation in this mode.

Initialization of the convolver is done using the CINO-7 bus to load configuration data and the filter kernel(s). The address lines AO-2 are used to address the internal registers for initialization. The configuration data is loaded using the AO-2, CINO-7 and LD\# controls as address, data and write enable, respectively. This interface is compatible with standard microprocessors without the use of any additional glue logic.

Filtered image data is output from the convolver over the DOUTO-19 bus. This output bus is 20-bits wide to provide room for growth during the convolution operation.

## 8-Bit Multiplier Array

The multiplier array consists of nine $8 \times 8$ multipliers. Each multiplier forms the product of a filter coefficient with a corresponding pixel in the input image. Input and coefficient data may be in either two's complement or unsigned integer format. The nine coefficients form a $3 \times 3$ filter kernel which is multiplied by the input pixel data and summed to form a sum of products for implementation of the convolution operation as shown below:

| FILTER KERNEL |  |  | INPUT DATA |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | C | P1 | P2 | P3 |
| D | E | F | P4 | P5 | P6 |
| G | H | I | P7 | P8 | P9 |

OUTPUT $=(A \times P 1)+(B \times P 2)+(C \times P 3)$
$+(\mathrm{D} \times \mathrm{P} 4)+(\mathrm{E} \times \mathrm{P} 5)+(\mathrm{F} \times \mathrm{P} 6)$
$+(\mathrm{G} \times \mathrm{P} 7)+(\mathrm{H} \times \mathrm{P} 8)+(1 \times \mathrm{P} 9)$

## Control Logic

The control logic (Figure 1) contains the Initialization Register and the Coefficient Registers. The control logic is updated by placing data on the CINO-7 bus and using the AO-2 and LD\# control lines to write to the addressed register (see Address Decoder). All of the control logic registers are unaffected by FRAME\#.


FIGURE 1. CONTROL LOGIC BLOCK DIAGRAM

## Initialization Register

The initialization register is used to appropriately configure the convolver for a particular application. It is loaded through the use of the CINO-7 bus along with the LD\# input. Bit 0 defines the input data and coefficients format (unsigned or two's complement); Bit 1 defines the mode of operation (1-D or 2-D); and Bits 2 and 3 determine the type of rounding to occur on the DOUTO-19 bus; The complete definition of the initialization register bits is given in Table 1.

TABLE 1. INITIALIZATION REGISTER DEFINITION

| INITIALIZATION REGISTER |  |  |
| :---: | :---: | :---: |
| BIT 0 |  | FUNCTION = Input \& Coefficient Data Format |
| 0 |  | Unsigned Integer format |
| 1 |  | Two's complement format |
| BIT 1 |  | FUNCTION = Operating Mode |
| 0 |  | 1-D 9-tap filter |
| 1 |  | 2-D $3 \times 3$ filter |
| 3 BIT |  | FUNCTION = Output Rounding |
| 0 | 0 | No Rounding |
| 0 | 1 | Round to 16 bits (i.e. DOUT19-4) |
| 1 | 0 | Round to 8 bits (i.e. DOUT19-12) |
| 1 | 1 | Not Valid |

## Coefficient Registers (CREGO, CREG1)

The control logic contains two coefficient register banks, CREGO and CREG1. Each of these register banks is capable of storing nine 8 -bit filter coefficient values ( $3 \times 3$ Kernel). The output of the registers are connected to the coefficient input of the corresponding multiplier in the $3 \times 3$ multiplier array (designated A through I). The register bank to be used for the convolution is selectable by writing to the approprite address (See address decoder). All registers in a given bank are enabled simultaneously, and one of the banks is always active.

For most applications, only one of the register banks is necessary. The user can simply load CREGO after power up, and use it for the entire convolution operation. (CREGO is the default register). The alternate register bank allows the user to maintain two sets of filter coefficients and switch between them in real time. The coefficient masks are loaded via the CINO-7 bus by using AO-2 and LD\#. The selection of the particular register bank to be used in processing is also done by writing to the appropriate address (See address decoder). For example, if CREGO is being used to provide coefficients to the multipliers, CREG1 can be updated at a low rate by an external processor; then, at the proper time, CREG1 can be selected, so that the new coeffi-
cient mask is used to process the data. Thus, no clock cycles have been lost when changing between alternate $3 \times 3$ filter kernels.

The nine coefficients must be loaded sequentially over the CINO-7 bus from A to I. The address of CREGO or CREG1 is placed on $\mathrm{AO}-2$, and then the coefficients are written to the corresponding coefficient register one at a time by using the LD\# input.

## Address Decoder

The address decoder (See Figure 1) is used for writing to the control logic of the HSP48901. Loading an internal register is done by selecting the destination register with the AO-2 address lines, placing the data on CINO-7, and asserting LD\# control line. When LD\# goes high, the data on CINO-7 is latched into the addressed register. The address map for the AO-2 bus is shown in Table 2.

While loading of the control logic registers is asynchronous to CLK, the target register in the control logic is being read synchronous to the internal clock. Therefore, care must be taken when modifying the convolver setup parameters during processing to avoid changing the contents of the registers near a rising edge of CLK. The required setup time relative to CLK is given by the specification TLCS. For example, in order to change the active coefficient register from CREGO to CREG1 during an active convolution operation, a write will be performed to the address for selecting CREG1 for internal processing ( $\mathrm{AO}-2=110$ ). In order to provide proper uninterrupted operation, LD\# should be deasserted at least TLCS prior to the next rising edge of CLK. Failure to meet this setup time may result in unpredictable results on the output of the convolver. Keep in mind that this requirement applies only to the case where changes are being made in the control logic during an active convolution operation. In a typical convolver configuration routine, where the configuration data is loaded prior to the actual convolution operation, this specification would not apply.

TABLE 2. ADDRESS MAP

| CONTROL LOGIC ADDRESS MAP |  |  |  |
| :--- | :--- | :--- | :--- |
| A2-0 |  | FUNCTION |  |
| 0 | 0 | 0 | Reserved for future use |
| 0 | 0 | 1 | Reserved for future use |
| 0 | 1 | 0 | Load Coefficient Register 0 (CREG0) |
| 0 | 1 | 1 | Load Coefficient Register 1 (CREG1) |
| 1 | 0 | 0 | Load Initialization Register (INT) |
| 1 | 0 | 1 | Select CREGO for Internal Processing |
| 1 | 1 | 0 | Select CREG1 for Internal Processing |
| 1 | 1 | 1 | No Operation |

## Control Signa/s

## Hold

The HOLD control input provides the ability to disable internal clock and stop all operations temporarily. HOLD is sampled on the rising edge of CLK and takes effect during the following clock cycle (Refer to Figure 2). This signal can be used to momentarily ignore data at the input of the convolver while maintaining its current output data and operational state.


FIGURE 2. HOLD OPERATION

## FRAME\#

The FRAME\# input initializes all internal flip flops and registers except for the coefficient and initialization registers. It is used as a reset between video frames and eliminates the need to re-initialize the entire HSP48901 or reload the coefficients. The registers and flip flops will remain in a reset state as long as FRAME\# is active. FRAME\# is an asynchronous input and may occur at any time. However, it must be deasserted at least tFS ns prior to the rising clock edge that is to begin operation for the next frame in order to ensure the new pixel data is properly loaded.

## Operation

A single HSP48901 can be used to perform $3 \times 3$ convolution on 8-bit image data. A block diagram of this configuration is shown in Figure 3. The inputs of an external data buffer (such as the HSP9501) are connected to the input data in parallel with the DIN1(0-7) lines; the outputs of the data buffer are connected to the DIN2(0-7) bus. A second external data buffer is connected between the outputs of the first buffer and the DIN3(0-7) inputs. To perform the convolution operation, a group of nine image pixels is multiplied by the $3 \times 3$ array of filter coefficients and their products are summed and sent to the output. For the example in figure 3, the pixel value in the output image at location $m, n$ is given by:

$$
\begin{aligned}
\operatorname{DOUT}(\mathrm{m}, \mathrm{n})= & A \times P \mathrm{Pm}-1, \mathrm{n}-1+B \times P m-1, \mathrm{n}+\mathrm{C} \times P \mathrm{Pm}-1, \mathrm{n}+1 \\
& +\mathrm{D} \times P \mathrm{Pm}, \mathrm{n}-1+E \times P m, n+F \times P m, n+1 \\
& +G \times P m+1, \mathrm{n}-1+\mathrm{H} \times P \mathrm{Pm}+1, \mathrm{n}+1 \times P m+1, \mathrm{n}+1
\end{aligned}
$$

This process is continually repeated until the last pixel of the last row of the image has been input. It can then start again with the first row of the next frame. The FRAME\# pin is used to clear the internal multiplier registers and DOUT0-19 registers between frames. The row length of the image to be convolved is limited only by the maximum length of the external data buffers.

The setup is straightforward. The user must first setup the HSP48901 by loading a new value into the initialization register. The coefficients can now be loaded one at a time from A to 1 via the CINO-7 coefficient bus, and the AO-2 and LD\# control lines.


INITIALIZATION
DATA

| A | B | C | $P_{M-1, N-1}$ | $P_{M-1, N}$ | $P_{M-1, N+1}$ |
| :--- | :--- | :--- | :--- | :--- | :--- |
| D | E | F | $P_{M, N-1}$ | $P_{M, N}$ | $P_{M, N+1}$ |
| F | H | I | $P_{M+1, N-1}$ | $P_{M+1, N}$ | $P_{M+1, N+1}$ |

FILTER KERNEL.
IMAGE DATA

## FIGURE 3. $3 \times 3$ KERNEL ON AN 8-BIT IMAGE

Multiple filter kernels can also be used on the same image data using the dual coefficient registers CREGO and CREG1. This type of filtering is used when the characteristics of the input pixel data change over the image in such a way that no one filter produces satisfactory results for the entire image. In order to filter such an image, the characteristics of the filter itself must change while the image is being processed. The HSP48901 can perform this function with the use of an external processor. The processor is used to calculate the required new filter coefficients, loads them into the coefficient register not in use, and selects the newly loaded coefficient register at the proper time. The first coefficient register can then be loaded with new coefficients in preparation for the next change. This can be carried out with no interruption in processing, provided that the new register is selected synchronous to the convolver CLK signal.

The HSP48901 can also operate as a one dimensional 9 tap FIR filter by programming the initialization register to 1-D mode (i.e. INT bit $1=$ ' 0 '). This configuration will provide for nine sequential input values to be multiplied by the coefficient values in the selected coefficient register and provide the proper filtered output. The input bus to be used when operating in this mode is the $\operatorname{DIN} 1(0-7)$ inputs.

The equation for the output in the 1-D 9-tap FIR case becomes:

$$
\begin{aligned}
\text { DOUTn }= & A \times D n-8+B \times D n-7+C \times D n-6+D \times D n-5 \\
& +E \times D n-4+F \times D n-3+G \times D n-2+H \times D n-1 \\
& +1 \times D n
\end{aligned}
$$

## Frame Rate

The total time to process an image is given by the formula:

$$
T=R \times C / F
$$

where: $\quad T=$ Time to process a frame
$R=$ number of rows in the image
$C=$ number of pixels in a row
$F=$ clock rate of the HSP48901

## Absolute Maximum Ratings

| upply Voltage | 8.0 V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ | PGA Package $=2.56 \mathrm{~W}$, PLCC Package $=1.9 \mathrm{~W}$ |
| Thermal Impedance Junction To Ambient ( $\theta_{\text {ja }}$ ) | PGA Package $=41^{\circ} \mathrm{C} / \mathrm{W}$, PLCC Package $=42.8{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Thermal Impedance Junction To Case ( $\theta_{\mathrm{jc}}$ ) | PGA Package $=16^{\circ} \mathrm{C} / \mathrm{W}$, PLCC Package $=14.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Gate Count | 13,594 Gates |
| Junction Temperature ( $\mathrm{T}_{\mathrm{J}}$ ) | PGA Package $=+175^{\circ} \mathrm{C}$, PLCC Package $=+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, Ten Seconds) | . $+300^{\circ} \mathrm{C}$ |
| ESD Classification | . Class 1 |
| CAUTION: Stresses above those listed in the "Absolut and operation of the device at these or any other con | e permanent damage to the device. This is a stress only rating the operational sections of this specification is not implied. |

## Operating Conditions

| Operating Voltage Range $+4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V}$ <br> Operating Temperature Range $0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
|  |  |


| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Logical One Input Voltage | VIH | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | VIL | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | VIHC | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | VILC | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | VOH | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | VOL | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | II | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | ICCSB | - | 500 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}$ <br> $\mathrm{Outp}_{\mathrm{CC}}=5.25 \mathrm{~V}$, |
| Operating Power Supply Current | ICCOP | - | 120 | mA | $\mathrm{f}=20 \mathrm{MHz}, \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}(\mathrm{NOte} 1)$ |

## Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CIN | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}$ CC $=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | CO | - | 15 | pF |  |

NOTES: 1. Power supply current is proportional to operating frequency. Typical rating for ICCOP is $6 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | -30 |  | -20 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCYCLE | 33 | - | 50 | - | ns |  |
| Clock Pulse Width High | TPWH | 13 | - | 20 | - | ns |  |
| Clock Pulse Width Low | TPWL | 13 | - | 20 | - | ns |  |
| Data Input Setup Time | TDS | 14 | - | 16 | - | ns |  |
| Data Input Hold Time | TDH | 0 | - | 0 | - | ns |  |
| Clock to Data Out | TOUT | - | 21 | - | 30 | ns |  |
| Address Setup Time | $\mathrm{T}_{\text {AS }}$ | 5 | - | 5 | - | ns |  |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ | 2 | - | 2 | - | ns |  |
| Configuration Data Setup Time | TCS | 10 | - | 12 | - | ns |  |
| Configuration Data Hold Time | ${ }^{\text {T }} \mathrm{CH}$ | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | TLPW | 13 | - | 20 | - | ns |  |
| LD\# Setup Time | TLCS | 31 | TCYCLE+2 | 40 | TCYCLE+2 | ns | Note 1 |
| HOLD Setup Time | THS | 10 | - | 12 | - | ns |  |
| HOLD Hold Time | $\mathrm{T}_{\mathrm{HH}}$ | 0 | - | 0 | - | ns |  |
| FRAME\# Pulse Width | TFPW | TCYCLE | - | TCYCLE | - | ns |  |
| FRAME\# Setup Time | TFS | 28 | - | 40 | - | ns | Note 2 |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 8 | - | 8 | ns | From 0.8 V to 2.0 V |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

NOTES: 1. This specification applies only to the case where a change in the active coefficient register is being selected during a convolution operation. It must be met in order to achieve predictable results at the next rising clock edge. In most applications, this selection will be made asynchronously, and the TLCS specification may be disregarded.
2. While FRAME\# is asynchronous with respect to CLK, it must be deasserted a minimum of $T_{F S}$ ns prior to the rising clock edge which is to begin loading new pixel data for the next frame.
3. A.C. Testing is performed as follows: Input levels (CLK Input) $=4.0 \mathrm{~V}$ and OV ; Input levels (All other Inputs) $=0 \mathrm{~V}$ to 3.0 V ; Input timing reference levels: $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$; Other timing references: $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$; Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

Test Load Circuit


Timing Waveforms



FRAME\# TIMING

HSP48908

## Features

## - Singie Chip $3 \times 3$ Kernel Convolution

- Programmable On-Chip Row Buffers
- DC to 32MHz Clock Rate
- Cascadable for Larger Kernels and Images
- On-Chip 8-Bit ALU
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- 8-Bit Signed or Unsigned Input and Coefficient Data
- 20-Bit Extended Precision Output
- Standard $\mu$ P Interface
- Low Power CMOS


## Applications

- Image Filtering
- Edge Detection
- Adaptive Filtering
- Real Time Video Filters


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP48908VC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP48908VC-32 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 100 Lead MQFP |
| HSP48908JC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP48908JC-32 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP48908GC-20 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP48908GC-32 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The Harris HSP48908 is a high speed Two Dimensional Convolver which provides a single chip implementation of a video data rate $3 \times 3$ kernel convolution on two dimensional data. It eliminates the need for external data storage through the use of the on-chip row buffers which are programmable for row lengths up to 1024 pixels.

There are internal register banks for storing two independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data. The pixel data path also includes an on-chip ALU for performing real-time arithmetic and logical pixel point operations.

Data is provided to the HSP48908 in a raster scan noninterlaced fashion, and is internally buffered on images up to 1024 pixels wide for the $3 \times 3$ convolution operation. Images with larger rows and convolution with larger kernel sizes can be accommodated by using external row buffers and/or multiple HSP48908s. Coefficient and pixel input data are 8-bit signed or unsigned integers, and the 20-bit convolver output guarantees no overflow for kernel sizes up to $4 \times 4$. Larger kernel sizes can be implemented however, since the filter coefficients will normally be less than their maximum 8-bit values.

The HSP48908 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs are TTL compatible.


## Pinouts (Continued)

100 LEAD MAFP
TOP VIEW


## Block Diagram




HSP48908

## Pin Descriptions

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 21, 42, 63, 84 |  | The +5 V power supply pins. $0.1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | $\begin{gathered} 19,48,54,61 \\ 69,76,82 \end{gathered}$ |  | The device ground. |
| CLK | 20 | I | Input and System clock. Operations are synchronous with the rising edge of this clock signal. |
| DINO-7 | 1-8 | I | Pixel Data input bus. This bus is used to provide the 8 -bit pixel input data to the HSP48908. The data must be provided in a synchronous fashion, and is latched on the rising edge of the CLK signai. |
| CINO-9 | 9-18 | 1 | Coefficient Input bus. This input bus is used to load the Coefficient Mask register(s), the Initialization register, the Row Buffer length register and the ALU microcode. It may also be used to provide a second operand input to the ALU. The definition of the CINO-9 bits is defined by the register address bits AO-2. The CINO-9 data is loaded to the addressed register through the use of the CS\# and LD\# inputs. |
| DOUTO-19 | $\begin{gathered} 49-53,55-60, \\ 62,64-68, \\ 70-72 \end{gathered}$ | 0 | Output Data bus. This 20-Bit output port is used to provide the convolution result. The result is the sum of products of the input data samples and their corresponding coefficients. The Cascade inputs CASIO-15 may also be added to the result by selecting the appropriate cascade mode in the Initialization register. |
| CASIO-15 | 29-41, 43-45 | 1 | Cascade Input bus. This bus is used for cascading multiple HSP48908s to allow convolution with larger kernels or row sizes. It may also be used to interface to external row buffers. The function of this bus is determined by the Cascade Mode bit (Bit 0) of the Initialization register. When this bit is set to a ' 0 ', the value on CASIO-15 is left shifted and added to DOUTO-19. The amount of the shift is determined by bits 7-8 of the Initialization register. While this mode is intended primarily for cascading, it may also be used to add an offset value, such as to increase the brightness of the convolved image. <br> When the Cascade mode bit is set to a ' 1 ', this bus is used for interfacing to external row buffers. In this mode the bus is divided into two 8 -bit busses (CASIO-7 and CASI8-15), thus allowing two additional pixel data inputs. The cascade data is sent directly to the internal multiplier array which allows for larger row sizes without using multiple HSP48908s. |
| CASO0-7 | 73-75, 77-81 | 0 | Cascade Output bus. This bus is used primarily during cascading to handle larger frames and/or kernel sizes. This output data is the data on DINO-7 delayed by twice the programmed internal row buffer length. |
| FRAME\# | 46 | 1 | Frame\# is an asynchronous new frame or vertical sync input. A low on this input resets all internal circuitry except for the Coefficient, ALU, AMC, EOR and INT registers. Thus, after a Frame\# reset has occurred, a new frame of pixels may be convolved without reloading these registers. |
| EALU | 28 | 1 | Enable ALU Input. This control line gates the clock to the ALU Register. When it is high, the data on CINO-7 is loaded on the next rising clock edge. When EALU is low, the last value loaded remains in the ALU register. |
| HOLD | 22 | 1 | The Hold Input is used to gate the clock from all of the internal circuitry of the HSP48908. This signal is synchronous, is sampled on the rising edge of CLK and takes effect on the following cycle. While this signal is active (high), the clock will have no effect on the HSP48908 and internal data will remain undisturbed. |
| RESET\# | 47 | 1 | Reset is an asynchronous signal which resets all internal circuitry of the HSP48908. All outputs are forced low in the reset state. |
| OE\# | 83 | I | Output Enable. The OE\# input controls the state of the Output Data bus (DOUTO-19). A LOW on this control line enables the port for output. When OE\# is HIGH, the output drivers are in the high impedance state. Processing is not interupted by this pin. |

## Pin Descriptions (Continued)

| NAME | PLCC PIN | TYPE |  |
| :---: | :---: | :---: | :--- |
| AO-2 | $25-27$ | I | DESCRIPTION <br> Control Register Address. These lines are decoded to determine which register <br> in the control logic is the destination for the data on the CINO-9 inputs. <br> Register loading is controlled by the AO-2,LD\# and CS\# inputs. |
| CS\# | 23 | 1 | Load Strobe. LD\# is used for loading the internal registers of the HSP48908. <br> When CS\# and LD\# are active, the rising edge of LD\# will latch the CINO-7 data <br> into the register specified by AO-2. |
| 24 | I | Chip Select. The Chip Select input enables loading of the internal registers. <br> When CS\# is low, the AO-2 address lines are decoded to determine the meaning <br> of the data on the CINO-7 bus. The rising edge of LD\# will then load the <br> addressed register. |  |

## Functional Description

The HSP48908 two-dimensional convolver performs convolution of $3 \times 3$ filter kernels. It accepts the image data in raster scan, non-interlaced format, convolves it with the filter kernel and outputs the filtered image. The input and filter kernel data are both 8-bits, while the output data is 20bits to prevent overflow during the convolution operation. The HSP48908 has internal storage for two $3 \times 3$ filter kernels and is capable of buffering two $1024 \times 8$-bit rows for true single chip operation at video frame rates. An 8-bit ALU in the input pixel data path allows the user to perform arithmetic and logical operations on the input data in real time during the convolution. Multiple devices can also be cascaded together for larger kernel convolution, larger frame sizes and increased precision.
Image data is input to the convolver via the DINO-7 bus. The data is then operated on by the ALU, stored in the row buffers and convolved with the $3 \times 3$ array of filter coefficients. The resultant output data is then latched into the output register. The row buffers are preprogrammed to the length of one row of the input image to enable the user to input the image data one pixel at a time in raster scan format without having to provide external storage.
Initialization of the convolver is done using the CINO-7 bus to load configuration data, such as the filter kernel(s) and the length of the row buffers. The address lines AO-2 are used to address the internal registers for initialization. The configuration data is loaded using the AO-2, CINO-9, CS\# and LD\# controls as address, data, chip select and write enable, respectively. This interface is compatible with standard microprocessors without the use of any additional glue logic.
Filtered image data comes out of the convolver over the DOUTO-19 bus. This output bus is 20-bits wide to provide room for growth during the convolution operation. The 20-bit bus will allow the use of up to $4 \times 4$ kernels (using multiple 48908's) without overflow. However, in practical applications, much larger kernel sizes can be implemented without overflow since the filter coefficients are typically much smaller than 8-bit full scale values. DOUTO-19 is also a registered, three state bus to facilitate cascading multiple chips and to allow the HSP48908 to reside on a standard microprocessor system bus.

Multiple convolvers can also be cascaded together for kernel sizes larger than $3 \times 3$ and for convolution on images with row lengths longer than 1024 pixels. The maximum kernel size is dependent upon the magnitude of the image data and the coefficients in a given application; care must always be taken with very large kernel sizes to prevent overflow of the 20-bit output.

## Data Input

Image data coming into the 2D Convolver passes through a programmable pipeline delay before being sent to the ALU. The amount of delay ( 1 to 4 clock cycles) is set in the initialization register during configuration setup (See Control Logic). Delays greater than one are used primarily in cascading multiple HSP48908s to align data sequences for proper output (See Operation).

## Arithmetic Logic Unit

The on-chip ALU provides the user with the capability of performing pixel point operations on incoming image data. Depending on the instruction in the ALU microcode register, the ALU can perform any one of 19 arithmetic and logical functions, and shift the resulting number left or right by up to 3 bits. Tables 1 and 2 show the available ALU functions and the 10-bit associated microcode to be loaded into the ALU microcode register. Note that the shifts take place on the output of the ALU and are completely independent of the logical or arithmetic operation being performed. The first input (A) of the ALU is taken from the pixel input bus (DINO-7). The second input (B) is taken from the ALU Register. The ALU Register is loaded via the CINO-7 bus while the EALU control line is valid (see EALU).
table 1. AlU Shift operations

| ALU MICROCODE REGISTER |  |  |  |
| :---: | :---: | :---: | :--- |
| REGISTER BIT |  |  |  |
| 9 | 8 | 7 | OPERATION |
| 0 | 0 | 0 |  |
| 0 | 0 | 1 | Shift Right 1 |
| 0 | 1 | 0 | Shift Right 2 |
| 0 | 1 | 1 | Shift Right 3 |
| 1 | 0 | 0 | Shift Left 1 |
| 1 | 0 | 1 | Shift Left 2 |
| 1 | 1 | 0 | Shift Left 3 |
| 1 | 1 | 1 | Not Valid |

TABLE 2. ALU PIXEL OPERATIONS

| REGISTER BIT |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 6 | 5 | 4 | 3 | 2 | 1 | 0 | OPERATION |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Logical (00000000) |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | Logical (111111111) |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | Logical (A) (Default) |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | Logical (B) |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | Logical (A\#) |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | Logical (B\#) |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | Arithmetic (A + B) |
| 1 | 0 | 0 | 1 | 0 | 1 | 0 | Arithmetic (A - B) |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | Arithmetic (B - A) |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Logical (A AND B) |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | Logical (A AND B\#) |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | Logical (A\# AND B) |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | Logical (A OR B) |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | Logical (A OR B\#) |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | Logical (A\# OR B) |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | Logical (A NAND B) |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | Logical (A NOR B) |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | Logical (A XOR B) |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | Logical (A XNOR B) |

## EALU

The EALU control pin enables loading of the ALU Register. While the EALU line is high, the data on CINO-7 is latched into the ALU Register on the rising edge of CLK. When EALU goes low, the current value in the ALU register is held until EALU is again asserted. Note that the ALU loading operation makes use of the CINO-7 inputs, but is completely independent of CS\# and LD\#. Therefore, in order to prevent overwriting an internal register, care must be taken to ensure that CS\# and LD\# are not active during an EALU cycle.

## Programmable Row Buffers

The programmable row buffers are used for buffering raster input data for the convolution operation. They can be thought of as programmable shift registers which can each store up to 1024 8-bit values, thus delaying each pixel by up to 1024 clock cycles. Functionally, each row buffer can be represented as a set of registers connected as a $1024 \times$ 8-bit serial shift register. The output of each buffer can be
represented by the equation $Q=D(n-r)$, where $Q$ is the row buffer output, $D$ is the buffer input, $n$ is the current clock cycle and $r$ is the preprogrammed row length of the input image. Since the two buffers are connected in series, the data at the cascade outputs (CASOO-7) is delayed by two row delays and may be used for cascading multiple convolvers for larger kernel sizes and/or row lengths. The programmable row buffers can also be bypassed by selecting the appropriate cascade mode in the initialization register. This mode allows the use of external row buffers for convolving with row lengths longer than 1024 pixels.

## 8-Bit Multiplier Array

The multiplier array consists of nine $8 \times 8$ multipliers. Each multiplier forms the product of a filter coefficient with a corresponding pixel in the input image. Input and coefficient data may be in either two's complement or unsigned integer format. The nine coefficients form a $3 \times 3$ filter kernel which is multiplied by the input pixel data and summed to form a sum of products for implementation of the convolution operation as shown below:

| INPUT DATA |  |  | FILTER KERNEL |
| :---: | :---: | :---: | :---: |
| P1 | P2 | P3 | ABC |
| P4 | P5 | P6 | DEF |
| P7 | P8 | P9 | G H I |
| $\begin{aligned} \text { OUTPUT }= & (\mathrm{A} \times \mathrm{P} 1)+(\mathrm{B} \times \mathrm{P} 2)+(\mathrm{C} \times \mathrm{P} 3) \\ & +(\mathrm{D} \times \mathrm{P} 4)+(\mathrm{E} \times \mathrm{P} 5)+(\mathrm{F} \times \mathrm{P} 6) \\ & +(\mathrm{G} \times \mathrm{P} 7)+(\mathrm{H} \times \mathrm{P})+(\mathrm{I} \times \mathrm{P} 9)+ \end{aligned}$ |  |  |  |

## Control Logic

The control logic (Figure 1) contains the ALU Microcode Register, the Initialization Register, the Row Length Register, and the Coefficient Registers. The control logic is updated by placing data on the CINO-9 bus and using the A0-2, CS\# and LD\# control lines to write to the addressed register (see Address Decoder). All of the control logic registers are loaded with their default values on RESET\#, and are unaffected by FRAME\#.

## ALU Microcode Register

The ALU microcode register is used to store the command word for the ALU. The ALU command word is a 10-bit instruction divided into two fields: the lower 7 bits determine the ALU operation and the upper 3 bits specify the number of shifts which occur. The ALU command words are defined in Tables 1 and 2 (See ALU section).


FIGURE 1. CONTROL LOGIC BLOCK DIAGRAM

## Initlalization Register

The initialization register is used to appropriately configure the convolver for a particular application. It is loaded through the use of the CINO-7 bus along with the CS\# and LD\# inputs. Bit 0 defines the type of cascade mode to be used; Bits 1 and 2 select the number of delays to be included in the input pixel data path; Bits 3 and 4 define the input and coefficient data format; Bits 5 and 6 determine the type of rounding to occur on the DOUTO-19 bus; Bits 7 and 8 define the shift applied to the cascade input data. The complete definition of the initialization register bits is given in Table 3.
table 3. initialization register definition

| INITIALIZATION REGISTER |  |  |
| :---: | :---: | :---: |
| BITO |  | FUNCTION = CASCADE MODE |
| $\begin{aligned} & 0 \\ & 1 \end{aligned}$ |  | Multiplier input from internal row buffers Multiplier input from external buffers |
| 2 BIT 1 |  | FUNCTION = INPUT DATA DELAY |
| $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | No data delay registers used One data delay register used Two data delay registers used Three data delay registers used |
| BIT 3 |  | FUNCTION = INPUT DATA FORMAT |
| 0 |  | Unsigned integer format Two's complement format |
| BIT 4 |  | FUNCTION = COEFFICIENT DATA FORMAT |
|  |  | Unsigned integer format Two's complement format |
| 6 BIT 5 |  | FUNCTION = OUTPUT ROUNDING |
| 0 0 1 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | No Rounding <br> Round to 16 bits (i.e. DOUT19-4) <br> Round to 8 bits (i.e. DOUT19-12) <br> Not Valid |
| 8 Bit 7 |  | FUNCTION = CASIO-15 INPUT SHIFT |
| 0 0 1 1 | 0 1 0 1 | No Shift <br> Shift CASIO-15 left two <br> Shift CASIO-15 left four <br> Shift CASIO-15 left eight |

## Row Length Register

The row length register is used to store the programmed number of delays for the internal row buffers. The programmed delay is set equal to the row length ( $r$ ) of the input image. The input pixel data is stored in the row buffers to allow corresponding pixels of adjacent rows to be synchronously sent to the mutiplier array for the convolution operation. The row length register is programmable with values from 0 to 1023, with 0 defined as a row length of 1024. Row lengths of 1 or 2 lead to meaningless results for a $3 \times 3$ kernel convolution, while a row length of 3 defines a $1 \times 9$ filter (See Operation section). The Row Length register is written through the use of AO-2, CS\# and LD\#. Once the row length register has been loaded, the convolver must be reset before a new row length can be entered, or else the new value will be ignored. After RESET\# returns high, the user has 1024 cycles of CLK to load the Row Length Register. After 1024 CLK cycles, the Row Length Register is automatically set to 0 (row length $=1024$ ) and further writes to this register are ignored.

## Coefficient Registers (CREG0, CREG1)

The control logic contains two coefficient register banks, CREGO and CREG1. Each of these register banks is capable of storing nine 8-bit filter coefficient values ( $3 \times 3$ Kernel). The output of the registers are connected to the coefficient input of the corresponding multiplier in the $3 \times 3$ multiplier array (designated A through I). The register bank to be used for the convolution is selectable by writing to the appropriate address (See address decoder). All registers in a given bank are enabled simultaneously, and one of the banks is always active.

For most applications, only one of the register banks is necessary. The user can simply load CREGO after power up, and use it for the entire convolution operation. (CREGO is the default register). The alternate register bank allows the user to maintain two sets of filter coefficients and switch between them in real time. The coefficient masks are loaded via the $C I N$ bus by using AO-2, CS\# and LD\#. The selection of the particular register bank to be used in processing is also done by writing to the appropriate address (See address decoder). For example, if CREGO is being used to provide coefficients to the multipliers, CREG1 can be updated at a low rate by an external processor; then, at the proper time, CREG1 can be selected, so that the new coefficient mask is used to process the data. Thus, no clock cycles have been lost when changing between alternate 3 x 3 filter kernels.

The nine coefficients must be loaded sequentially over the CINO-7 bus from A to I. The address of CREGO or CREG1 is placed on AO-2, and then the nine coefficients are written to the corresponding coefficient register one at a time by using the CS\# and LD\# inputs.

## Address Decoder

The address decoder (See Figure 1) is used for writing to the control logic of the HSP48908. Loading an internal register is done by selecting the destination register with the AO-2 address lines, placing the data on CINO-9, and asserting the CS\# and LD\# control lines. When either CS\# or L.D\# goes high, the data on the CINO-9 lines is latched into the addressed register. The address map for the AO-2 bus is shown in Table 4.
While loading of the control logic registers is asynchronous to CLK, the target register in the control logic is being read synchronous to the internal clock. Therefore, care must be taken when modifying the convolver setup parameters during processing to avoid changing the contents of the registers near a rising edge of CLK. The required setup time relative to CLK is given by the specification TLCS. For example, in order to change the active coefficient register from CREGO to CREG1 during an active convolution operation, a write will be performed to the address for selecting CREG1 for internal processing ( $\mathrm{A} 2-\mathrm{O}=110$ ). In order to provide proper uninterrupted operation, LD\# should be deasserted at least TLCS prior to the next rising edge of CLK. Failure to meet this setup time may result in unpredictable results on the output of the convolver for one clock cycle. Keep in mind that this requirement applies only to the case where changes are being made in the control logic during an active convolution operation. In a typical convolver configuration routine, this specification would not be applicable.
table 4. ADDRESS MAP

| CONTROL LOGIC ADDRESS MAP |  |
| :--- | :--- |
| A2-0 | Function |
| 000 | Load Row Length Register (RLR) |
| 001 | Load ALU MIcrocode Register (AMC) |
| 010 | Load Coefficient Register 0 (CREGO) |
| 011 | Load Coefficient Register 1 (CREG1) |
| 100 | Load Initialization Register (INT) |
| 101 | Select CREGO for Internal Processing |
| 110 | Select CREG1 for Internal Processing |
| 111 | No Operation |

## Cascade I/O

## Cascade Input

The cascade input lines (CASIO-15) have two primary functions. The first is used to allow convolutions with kernel sizes larger than $3 \times 3$. This can be implemented by connecting the DOUT bus of one convolver to the cascade inputs of another. The second function is for convolution on images wider than 1024 pixels. This type of operation can be implemented by using external row buffers to supply the pixel input data to the CASIO-15 inputs. The cascade input functions are determined by Initialization Register bit 0. When this bit is set to a ' 0 ', the cascade input data is added
to the convolver output. In this manner, multiple convolvers can be used to implement larger kernel convolution. When Initialization Register bit 0 is a ' 1 ', the data on CASIO-15 is divided into two 8-bit portions and is sent to the $3 \times 3$ multiplier array (Refer to Block Diagram). This mode of operation allows the use of external row buffers for convolution of images with row sizes larger than 1024. Examples of these configurations are given in the Operations section of this specification.
The data on the cascade inputs (CASIO-15) can also be left shifted by $0,2,4$, or 8 bits. The amount of shift is determined by bits 7 and 8 of the Initialization Register (See Table 3). CASIO-15 is shifted by the specified number of bits and is added to the 20-bit output DOUT 0-19. The shifting function provides a method for cascading multiple HSP48908s and allowing a selectable amount of output growth while maximizing the resolution of the convolver result.

The cascade inputs can also be used as a simple way to add an offset to the convolved image. Bit 0 of the configuration register would be set to ' 0 ', and the desired offset placed on the CASIO-15 inputs. While multiple offets can be used and changed during the convolution operation, note that the required data setup and hold times with respect to CLK (TDS and TDH) must be met.

## Cascade Output

The cascade output lines (CASOO-7) are outputs from the second row buffer. Data at these outputs is the input pixel data delayed by two times the preprogrammed value in the row length register. The cascade outputs are used to cascade multiple convolvers by connecting the cascade outputs of one device to the data inputs of another (See Operation section).

## Control Signals

## HOLD

The HOLD control input provides the ability to disable internal clock and stop all operations temporarily. HOLD is sampled on the rising edge of CLK and takes effect during the following clock cycle (Refer to Figure 2). This signal can be used to momentarily ignore data at the input of the convolver while maintaining its current output data and operational state.


FIGURE 2. HOLD OPERATION

## RESET\#

The RESET\# signal initializes all internal flip flops and registers in the HSP48908. It is an asynchronous signal, and the convolver will remain in the reset state as long as RESET\# is asserted. On reset, all internal registers are set to zero or their default values, and all outputs are forced low. Following a reset, the default values in the internal registers will define the following mode of operation: internal row buffers used, line length $=1024$, no input data delay, logical A operation: output of ALU = A input (DINO-7) output rounding and unsigned input data format.

The convolver can be reset at any time, but must be reset before updating the Row Length register in order to provide proper operation. After RESET\# returns high, the user has 1024 cycles of CLK to load the Row Length Register. After 1024 CLK cycles, the Row Length Register is automatically set to 0 (row length $=1024$ ) and further writes to this register are ignored.

## FRAME\#

This FRAME\# input initializes all internal flip flops and registers except for the coefficient, ALU, ALU microcode, row length, and initialization registers. It is used to reset the convolver between video frames and eliminates the need to re-initialize the entire convolver or reload the coefficients. FRAME\# is an asynchronous input and may occur at any time. However, it must be deasserted at least TFS ns prior to the rising clock edge that is to begin operation for the next frame. While FRAME\# is asserted, the registers and flipflops will remain in the reset state.

## Operation

The HSP48908 has three basic modes of operation: single chip mode, operation with external row buffers and multiple devices cascaded together for larger convolution kernels and/or longer row lengths. The mode of operation is defined by the contents of the initialization register, and can be modified at any time by a microprocessor or other external means.

## Single Chip Mode

A single HSP48908 can be used to perform $3 \times 3$ convolution on 8-bit image data with row lengths up to 1024. A block diagram of this configuration is shown in Figure 3. In this mode of operation, the image data is input into the DINO-7 bus in a raster scan order starting with the upper left pixel. To perform the convolution operation, a group of nine image pixels is multiplied by the $3 \times 3$ array of filter coefficients and their products are summed and sent to the output. For the example in Figure 3, the pixel value in the output image at location $(m, n)$ is given by:

$$
\begin{aligned}
& \operatorname{POUT}(m, n)\left(A \times P_{m-1, n-1}\right)+\left(B \times P_{m-1, n}\right)+\left(C \times P_{m-1, n+1}\right) \\
&+\left(D \times P_{m, n-1}\right)+\left(E \times P_{m, n}\right)+\left(F \times P_{m, n+1}\right) \\
&+\left(G \times P_{m+1, n-1)}+\left(H \times P_{m+1, n}\right)+\left(1 \times P_{m+1, n+1}\right)\right.
\end{aligned}
$$

This process is continually repeated until the last pixel of the last row of the image has been input. It can then start again with the first row of the next frame. The FRAME\# pin is used
to clear the row buffers, multiplier input latches and DOUTO-19 registers between frames.
The setup for single chip operation is straightforward. After reset, the convolver is configured for row lengths of 1024 pixels, no input data delay, no ALU pixel point operations, no output rounding, and an unsigned input format. The user can change this default setup by loading new values into the ALU microcode, initialization and row length registers. RESET\# also clears the coefficient registers and CREGO is selected for internal processing. The user can now load the coefficients one at a time from A to I via the CINO-7 inputs and the LD\# and CS\# control lines.
Multiple filter kernels can also be used on the same image data using the dual coefficient registers CREGO and CREG1. This type of filtering is used when the characteristics of the input pixel data change over the image in such a way that no single filter produces satisfactory results for the entire image. In order to filter such an image, the characteristics of the filter itself must change while the image is being processed. The HSP48908 can perform this function with the use of an external processor. The processor is used to calculate the required new filter coefficients, loads them into the coefficient register not in use, and selects the newly loaded coefficient register at the proper time. The first coefficient register can then be loaded with new coefficients in preparation for the next change. This can be carried out with no interruption in processing, provided that the new register is selected synchronous to the convolver CLK signal.
The HSP48908 can also operate as a one dimensional 9 tap FIR filter by programming the row buffer length register with a value of 3 and setting the initialization register bit 0 to a ' 0 '. This configuration will provide for nine sequential input values in the input to be multiplied by the coefficient values in the selected coefficient register and provide the proper filtered output. The equation for the output then becomes:

$$
\begin{aligned}
D_{\text {OUTn }}= & A \times D_{n-8}+B \times D_{n-7}+C \times D_{n-6}+D \times D_{n-5} \\
& +E \times D_{n-4}+F \times D_{n-3}+G \times D_{n-2}+H \times D_{n-1} \\
& +I \times D_{n}
\end{aligned}
$$



| FILTER KERNEL | IMAGE DATA |  |  |
| :---: | :--- | :--- | :--- |
| ABC | $P_{m-1, n-1}$ | $P_{m-1, n}$ | $P_{m-1, n+1}$ |
| DEF | $P_{m, n-1}$ | $P_{m, n}$ | $P_{m, n+1}$ |
| GHI | $P_{m+1, n-1}$ | $P_{m+1, n}$ | $P_{m+1, n+1}$ |

FIGURE 3. $3 \times 3$ KERNEL ON AN 8-BIT, $1024 \times$ N IMAGE

## Use Of External Row Buffers

External row buffers may be used when frames with row sizes larger than 1024 pixels are desired. To use the HSP48908 in this mode, the cascade mode control bit (bit 0 ) of the initialization register is set to ' 1 ' to allow the data on the cascade inputs CASIO-15 to go to the multiplier array. The inputs of one external row buffer (such as the HSP9500) are connected to the input data in parallel with the DINO-7 lines of the convolver; and its outputs are connected to the CASIO-7 inputs (See Figure 4). A second external row buffer is connected between the outputs of the first row buffer and the CASI8-15 inputs of the convolver. The convolution operation can then be performed by the HSP48908 in the same manner as the single chip mode. The row length in this configuration is limited only by the maximum length of the external row buffers. Note that when using the convolver in this configuration, the programmable input data delays and ALU will only operate on the data entering the DINO-7 inputs (i.e. the bottom row of the $3 \times 3$ sum of products). If higher order filters or pixel point operations are required when using external row buffers, these functions must be implemented externally by the user.


FIGURE 4. USING EXTERNAL ROW BUFFERS WITH THE HSP48908

## Cascading Multiple HSP48908's

Multiple HSP48908s are capable of being cascaded to perform convolution on images with row lengths longer than 1024 pixels and with kernel sizes larger than $3 \times 3$. Figure 5 illustrates the use of two HSP48908s to perform a $3 \times 3$ kernel convolution on a $2 \mathrm{~K} \times \mathrm{N}$ frame. In this case, the cascade mode control bit (Bit 0 ) of both initialization registers are set to a ' $O$ '. The loading of the coefficients is

| $3 \times 3$ FILTER <br> KERNEL | COEFFICIENT MASKS |  |
| :---: | :---: | :---: |
|  | CONVOLVER \#1 | CONVOLVER \#2 |
| ABC | DEF | ABC |
| DEF | 000 | 000 |
| GHI | GHI | 000 |



FIGURE 5. $3 \times 3$ KERNEL CONVOLUTION ON A $2 \mathrm{~K} \times$ N IMAGE
accomplished just as before. However, the $3 \times 3$ mask is divided into two portions for proper convolution output as follows: Convolver \#1 = DEF000GHI and Convolver \#2 = ABC000000.

The same configuration can be used to perform $3 \times 5$ convolution on a $1 \mathrm{~K} \times \mathrm{N}$ frame simply by setting up the coefficients of the convolvers to implement the $3 \times 5$ mask as indicated below:

| $3 \times 5$ FLLTER |
| :---: | :---: | :---: |
|  |$\quad$| COEFFICIENT MASKS |  |
| :---: | :---: |
|  | CONVOLVER \#1 |
| CONVOLVER \#2 |  |
| ABC | GHI |
| DEF | JKL |
| GHI | MNO |
| JKL |  |
| MNO |  |

In addition to larger frames, larger kernels can also be addressed through cascadability. An example of the configuration for a $5 \times 5$ kernel convolution on a $1 \mathrm{~K} \times \mathrm{N}$ frame is shown in Figure 6. Note that in this configuration, convolver \#2 incorporates a 3 clock cycle delay $(z-3)$ and convolvers 3 and 4 incorporate 2 clock cycle delays ( $z-2$ ) at their pixel inputs. These delays are required to ensure proper data alignment in the final sum of products output of the cascaded convolvers. The number of delays required at the pixel input is programmable through the use of bits 1 and 2 of the initialization register (Refer to Table 3).


| $5 \times 5$ | CONVOLVER |  |
| :---: | :---: | :---: |
| FILTERKERNEL | COEFFICIENT MASKS |  |
| ABCDE | OKL | OAB |
| FGHIJ | OPQ | OFG |
| KLMNO | OUV | OOO |
| PQRST |  |  |
| UVWXY | MNO | CDE |
|  | RST | HIJ |
|  | WXY | OOO |

FIGURE 6. $5 \times 5$ KERNEL CONVOLUTION ON A $1 K \times N$ IMAGE

In any of the cascade configurations, only 16 bits of the 20bit output (DOUTO-19) can be connected to the 16 cascade inputs (CASIO-15) of another convolver. Which 16 bits are chosen depends upon the amount of growth expected at the convolver output. The amount of growth is dependent on the input pixel data and the coefficients selected for the convolution operation. The maximum possible growth is calculated in advance by the user, and the convolvers are set up to appropriately shift the cascade input data through the use of bits 7 and 8 of the initialization register (See Cascade I/O). Refering to Figure 6, if the maximum growth out of convolver \#1 extends into bit 16 or 17, then DOUT2-17 are connected to the cascade inputs of convolver \#3, which is programmed to shift the input data left by two bits. Likewise, if the data out of convolver \#3 grows into bit 18 or 19, then DOUT4-19 are connected to the CASIO-15 inputs of convolver \#2, which is programmed to shift the input left by 4 bits.

## Cascading For Row Sizes Larger Than 1024

Combining large images with large kernels is accomplished by implementing external row buffers, external data delay registers and external adders. Figure 7 illustrates a circuit
for implementation of a $5 \times 5$ convolution on a $2 \mathrm{~K} \times \mathrm{N}$ image. The $5 \times 5$ coefficient mask is again distributed among the four HSP48908's. The width of the DOUT path to be used in this case is dependent on the amount of resolution required and the amount of growth expected at the output.

## Frame Rate

The total time to process an image is given by the formula:
$T=R \times C / F$
where:
$T=$ time to process a frame
$R=$ number of rows in the image
C = number of pixels in a row
$F=$ clock rate of the HSP48908
Note that the size of the kernel does not enter into the equation. Convolvers cascaded for larger kernels or larger frame sizes, as in the examples shown, process the image in the same amount of time as a single HSP48908 convolving the image with a $3 \times 3$ kernel. Therfore, there is no performance degradation when cascading multiple HSP48908s.


FIGURE 7. $5 \times 5$ KERNEL CONVOLUTION ON A $2 K \times N$ IMAGE

## Absolute Maximum Ratings



CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
+4.75 V to +5.25 V
Operating Temperature Range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
D.C. Electrical Specifications $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | v | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | v | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $1 \mathrm{OH}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| I/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ or $G N D$ |
| Standby Power Supply Current | ${ }^{\text {I CCSb }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V},$ Outputs Open |
| Operating Power Supply Current | ICCOP | - | 140 | mA | $\begin{aligned} & \mathrm{f}=20 \mathrm{MHz}, \mathrm{~V}_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \text { Note } 1 \end{aligned}$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 12 | pF |  |

NOTES: 1. Power supply current is proportional to operating frequency.
Typical rating for $\mathrm{I}_{\mathrm{CCOP}}$ is $7.0 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications $\left(V_{C C}=5.0 V^{2} 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | -32 (32MHz) |  | -20 (20MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCycle | 31 | - | 50 | - | ns |  |
| Clock Pulse Width High | TPWH | 12 | - | 20 | - | ns |  |
| Clock Pulse Width Low | TPWL | 13 | - | 20 | - | ns |  |
| Data Input Setup Time | TDS | 13 | - | 14 | - | ns |  |
| Data Input Hold Time | TDH | 0 | - | 0 | - | ns |  |
| Clock to Data Out | TOUT | - | 16 | - | 22 | ns |  |
| Address Setup Time | $\mathrm{T}_{\text {AS }}$ | 13 | - | 13 | - | ns |  |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ | 0 | - | 0 | - | ns |  |
| Configuration Data Setup Time | TCDS | 14 | - | 16 | - | ns |  |
| Configuration Data Hold Time | TCDH | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | TLPW | 12 | - | 20 | - | ns |  |
| LD\# Setup Time | TLCS | 25 | - | 30 | - | ns | Note 1 |
| CINO-7 Setup to CLK | TCS | 14 | - | 16 | - | ns |  |
| CS\# Setup To LD\# | TCSS | 0 | - | 0 | - | ns |  |
| CINO-7 Hold Time From CLK | $\mathrm{T}^{\text {CH }}$ | 0 | - | 0 | - | ns |  |
| CS\# Hold From LD\# | TCSH | 0 | - | 0 | - | ns |  |
| RESET\# Pulse Width | TRPW | 31 | - | 50 | - | ns |  |
| FRAME\# Setup To Clock | TFS | 21 | - | 25 | - | ns | Note 2 |
| FRAME\# Pulse Width | TFPW | 31 | - | 50 | - | ns |  |
| EALU Setup Time | TES | 12 | - | 14 | - | ns |  |
| EALU Hold Time | $\mathrm{T}_{\text {EH }}$ | 0 | - | 0 | - | ns |  |
| HOLD Setup Time | THS | 11 | - | 12 | - | ns |  |
| HOLD Hold Time | THH | 1 | - | 1 | - | ns |  |
| Output Enable Time | TEN | - | 16 | - | 22 | ns | Note 3 |
| Output Disable Time | Toz | - | 28 | - | 32 | ns | Note 5 |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 6 | - | 6 | ns | From 0.8 to 2.0 V Note 5 |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 6 | - | 6 | ns | From 2.0 to 0.8 V Note 5 |

NOTES: 1. This specification applies only to the case where the HSP48908 is being written to during an active convolution cycle. It must be met in order to acheive predictable results at the next rising clock edge. in most applications, the configuration data and coefficients are loaded asynchronously and the TLCS specification may be disregarded.
2. While FRAME\# is an asynchronous signal, it must be deasserted a minimum of $T_{F S}$ ns prior to the rising clock edge which is to begin loading pixel data for a new frame.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $C_{L}=40 \mathrm{pF}$.
4. A.C. Testing is performed as follows: Input levels (CL.K Input) 4.0 and $O V$, Input levels (All other Inputs) OV and 3.0V, Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$, Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
5. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests
Timing Waveforms


THREE STATE CONTROL


## Timing Waveforms (Continued)



FRAME\#/RESET\# TIMING


## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Single Chip $3 \times 3$ Kernel Convolution
- Programmable On-Chip Row Buffers
- DC to $\mathbf{2 7 M H z}$ Clock Rate
- Cascadable for Larger Kernels and Images
- On-Chip 8-Bit ALU
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- 8-Bit Signed or Unsigned Input and Coefficient Data
- 20-Bit Extended Precision Output
- Standard $\mu$ P Interface


## Applications

- Image Filtering
- Edge Detection
- Adaptive Filtering
- Real Time Video Filters


## Ordering Information

| PART NUMBER | TEMP. RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP48908GM-20/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |
| HSP48908GM-27/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 84 Lead PGA |

## Description

The Harris HSP48908/883 is a high speed Two Dimensional Convolver which provides a single chip implementation of a video data rate $3 \times 3$ kernel convolution on two dimensional data. It eliminates the need for external data storage through the use of the on-chip row buffers which are programmable for row lengths up to 1024 pixels.

There are internal register banks for storing two independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data. The pixel data path also includes an on-chip ALU for performing real-time arithmetic and logical pixel point operations.

Data is provided to the HSP48908/883 in a raster scan noninterlaced fashion, and is internally buffered on images up to 1024 pixels wide for the $3 \times 3$ convolution operation. Images with larger rows and convolution with larger kernel sizes can be accommodated by using external row buffers and/or multiple HSP48908/883s. Coefficient and pixel input data are 8bit signed or unsigned integers, and the 20-bit convolver output guarantees no overfiow for kernel sizes up to $4 \times 4$. Larger kernel sizes can be implemented however, since the filter coefficients will normally be less than their maximum 8bit values.

The HSP48908/883 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs are TTL compatible.

## Pinout



## Absolute Maximum Ratings

Supply Voltage
. 8.0 V
Input, Output or I/O Voltage Applied .... GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10 sec ) . .................... $+300^{\circ} \mathrm{C}$
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1
ESD Classicaion ........................................................... 1

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $35.0^{\circ} \mathrm{C} / \mathrm{W}$ | $7.7{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package |  | 1.45W |
| Gate Count. | 190,0 | sist |

CAUTION: Absolute maximum ratings are limiting values, applied individually beyond which the serviceability of the circuit may be impaired. Functional operability under any of these conditions is not necessarily implied.

## Recommended Operating Condltions

Operating Temperature Range . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| D.C. PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical 1 Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical 0 Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\mathrm{ILC}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { (Note 1) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { (Note 1) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O <br> Leakage Current | 10 | $\begin{aligned} & \mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ICCSB | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \\ & \text { Outputs Open (Note 4) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { Outputs Open, } \\ & \text { (Notes 2,4) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Notes 3, 4) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES: 1. Interchanging of force and sense conditions is permitted
2. Operating Supply Current is proportional to frequency, typical rating is $8.0 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $\mathrm{f}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$, $V_{\text {IHC }}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{LLC}}=0.4 \mathrm{~V}$.
4. Loading is a specified in the test load circuit with $C_{L}=40 p F$.

## HSP48908/883

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Tested at: $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Note 4)

| PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -27 (27MHz) |  | -20 (20MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | TCYCLE |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| Clock Pulse Width High | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock Pulse Width Low | TPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Data Input Setup Time | TDS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | - | 17 | - | ns |
| Data Input Hold Time | ${ }^{\text {TDH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Clock to Data Out | TOUT |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 28 | ns |
| Address Setup Time | $\mathrm{T}_{\text {AS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Configuration Data Setup Time | $\mathrm{T}_{\text {CDS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 20 | - | ns |
| Configuration Data Hold Time | ${ }^{\text {T }}$ CDH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| LD\# Pulse Width | TLPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| LD\# Setup Time | TLCS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 37 | - | ns |
| CIN7-0 Setup to CLK | TCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 20 | - | ns |
| CIN7-0 Hold from CLK | ${ }^{\text {T }} \mathrm{CH}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CS\# Setup to LD\# | TCSS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CS\# Hold from LD\# | $\mathrm{T}^{\text {CSSH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| RESET\# Pulse Width | TRPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| FRAME\# Setup to CLK | TFS | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 30 | - | ns |
| FRAME\# Pulse Width | TFPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| EALU Setup Time | TES |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 17 | - | ns |
| EALU Hold Time | TEH |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| HOLD Setup Time | THS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 14 | - | ns |
| HOLD Hold Time | THH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| Output Enable Time | TEN | Note 3 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 28 | ns |

NOTES: 1. This specification applies only to the case where the HSP48908/ 883 is being written to during an active convolution cycle. It must be met in order to achieve predictable results at the next rising clock edge. In most applications, the configuration data and coefficients are loaded asynchronously and the TLCS specification may be disregarded.
2. While FRAME\# is an asynchronous signal, it must be deasserted a minimum of $T_{F S} n s$ prior to the rising clock edge which is to begin loading pixel data for a new frame.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
4. A.C. Testing is performed as follows: Input levels (CLK Input) 4.0 V and OV , Input levels (All other Inputs) $O \mathrm{~V}$ and 3.0 V , Timing Reference Levels $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$. Output load per test load circuit with $C_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -27 |  | -20 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $C_{1 N}$ | $\begin{aligned} & v_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, \mathrm{All} \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Capacitance | $\mathrm{Co}_{0}$ | $\begin{aligned} & v_{c c}=\text { Open, } \\ & f=1 \mathrm{MHz}, \text { All } \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}^{\prime}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Disable Time | TOZ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 40 | ns |
| Output Rise Time | $\mathrm{T}_{\text {R }}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 6 | - | 6 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | 6 | - | 6 | ns |

NOTES: 1. Parameters listed in Table 3 are controlled via design or process
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$. parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Burn-In Circuit



PGA BURN-IN SCHEMATIC

| PIN NAME | PGA PIN | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| CIN2 | A1 | F13 |
| CINO | A2 | F12 |
| DIN7 | A3 | F7 |
| DIN5 | A4 | F5 |
| DIN2 | A5 | F2 |
| DIN1 | A6 | F1 |
| OE | A7 | F10 |
| CASO. 1 | A8 | VCC/2 |
| CASO. 3 | A9 | $V_{C C / 2}$ |
| CASO. 4 | A10 | $V_{C C / 2}$ |
| CASO. 6 | A11 | $V_{C C} / 2$ |
| CIN5 | B1 | F12 |
| CIN3 | B2 | F13 |
| CIN1 | B3 | F12 |
| DIN6 | B4 | F6 |
| DIN3 | B5 | F3 |
| CASO. 0 | B6 | $V_{C C / 2}$ |
| GND | B7 | GND |
| CASO. 2 | B8 | $V_{C C / 2}$ |
| GND | B9 | GND |
| CASO. 5 | B10 | $V_{C C / 2}$ |
| POUTO | B11 | $V_{C C / 2}$ |
| CIN6 | C1 | F13 |
| CIN4 | C 2 | F13 |
| DIN4 | C5 | F4 |
| DINO | C6 | FO |
| VCC | C7 | $V_{C C}$ |
| CASO. 7 | C10 | VCC/2 |


| PIN NAME | PGA PIN | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| POUT1 | C11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CIN8 | D1 | F14 |
| CIN7 | D2 | F12 |
| POUT2 | D10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| GND | D11 | GND |
| CLK | E1 | FO |
| GND | E2 | GND |
| CIN9 | E3 | F14 |
| POUT3 | E9 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT4 | E10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT5 | E11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| A1 | F1 | F13 |
| $V_{C C}$ | F2 | $\mathrm{V}_{\text {cc }}$ |
| HOLD | F3 | F14 |
| POUT7 | F9 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| POUT9 | F10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT6 | F11 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| CS | G1 | F12 |
| A2 | G2 | F14 |
| LOAD | G3 | F11 |
| VCC | G9 | $V_{C C}$ |
| GND | G10 | GND |
| POUT8 | G11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| AO | H1 | F12 |
| EALU | H2 | F8 |
| POUT11 | H10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT10 | H11 | $\mathrm{VCc} / 2$ |
| CASI. 15 | J1 | F7 |


| PIN NAME | PGA PIN | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| CASI. 13 | J2 | F5 |
| CASI. 5 | J5 | F5 |
| CASI. 2 | J6 | F2 |
| CASI. 1 | J7 | F1 |
| POUT14 | J10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT12 | J11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| CASI. 14 | K1 | F6 |
| CASI. 11 | K2 | F3 |
| CASI. 10 | K3 | F2 |
| CASI. 7 | K4 | F7 |
| CASI. 4 | K5 | F4 |
| $V_{C C}$ | K6 | Vcc |
| FRAME | K7 | F15 |
| POUT19 | K8 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| POUT16 | K9 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| GND | K10 | GND |
| POUT13 | K11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CASI. 12 | L. 1 |  |
| CASI. 9 | L2 | F1 |
| CASII 8 | L3 | FO |
| CASI. 6 | L. 4 | F6 |
| CASI. 3 | L5 | F3 |
| RESET | L6 | F16 |
| CASI. 0 | L7 | FO |
| GND | L8 | GND |
| POUT18 | L.9 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| POUT17 | L10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| POUT15 | L11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |

NOTES: 1. $V_{C C} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.

[^4]5. $F 0=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots F 11=F 10 / 2$, 40-60\% Duty Cycle.
6. Input Voltage Limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max., $\mathrm{V}_{\mathbb{I}}=4.5 \mathrm{~V} \pm 10 \%$.


## Features

- DC to 32 MHz Operating Frequency
- Programmable Buffer Length from 2 to 1281 Words
- Supports Data Words to 10-Bits
- Clock Select Logic for Positive or Negative Edge System Clocks
- Data Recirculate or Delay Modes of Operation
- Expandable Data Word Width or Buffer Length
- Three-State Outputs
- TTL Compatible Inputs/Outputs
- Low Power CMOS


## Applications

- Sample Rate Conversion
- Data Time Compression/Expansion
- Software Controlled Data Alignment
- Programmable Serial Data Shifting
- Audio/Speech Data Processing Video/lmage Proc̣essing


## Video/lmage Processing

- 1-H Delay Line of 910 NTSC, 1135 PAL or 1280 Samples:
- High Resolution Monitor Delay Line
- Comb Filter Designs
- Progressive Scanning Display
- TV Standards Conversion
- Image Processing

Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :---: |
| HSP9501JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 44 Lead PLCC |
| HSP9501JC- 32 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 44 Lead PLCC |

## Description

The HSP9501 is a 10 -Bit wide programmable data buffer designed for use in high speed digital systems. Two different modes of operation can be selected through the use of the MODSEL input. In the delay mode, a programmable data pipeline is created which can provide 2 to 1281 clock cycles of delay between the input and output data. In the data recirculate mode, the output data path is internally routed back to the input to provide a programmable circular buffer.

The length of the buffer or amount of delay is programmed through the use of the 11-bit length control input port (LCO10 ) and the length control enable (LCEN\#). An 11-bit value is applied to the LC0-10 inputs, LCEN\# is asserted, and the next selected clock edge loads the new count value into the length control register. The delay path of the HSP9501 consists of two registers with a programmable delay RAM between them, therefore, the value programmed into the length control register is the desired length - 2. The range of values which can be programmed into the length control register are from 0 to 1279, which in turn results in an overall range of programmable delays from 2 to 1281.

Clock select logic is provided to allow the use of a positive or negative edge system clock as the CLK input to the HSP9501. The active edge of the CLK input is controlled through the use of the CLKSEL input. All synchronous timing (i.e. data setup, hold and output delays) are relative to the clock edge selected by CLKSEL. An additional clock enable input (CLKEN\#) provides a means of disabling the internal clock and holding the existing contents temporarily. All outputs of the HSP9501 are three-state outputs to allow direct interfacing to system or multi-use busses.

The HSP9501 is recommended for digital video processing or any applications which require a programmable delay or circular data buffer.


## Pin Descriptions

| NAME | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | 12,34 |  | The +5 V power supply pin. $\mathrm{A} 0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and GND pin is recommended. |
| GND | 13,33 |  | The device ground. |
| CLK | 1 | I | Input Clock. This clock signal is used to control the data movement through the programmable buffer. It is also the signal which latches the input data, length control word and mode select. Input setup and hold times with respect to the clock must be met for proper operation. |
| DIO-9 | $\begin{gathered} 27,29-32, \\ 35-39 \\ \hline \end{gathered}$ | I | Data Inputs. This 10-bit input port is used to provide the input data. When MODSEL is low, data on the DIO-9 inputs is latched on the clock edge selected by CLKSEL. |
| DOO-9 | $\begin{gathered} 7-11, \\ 14-18 \end{gathered}$ | 0 | Data Outputs. This 10-bit port provides the output data from the internal delay registers. Data latched into the DIO-9 inputs will appear at the DOO-9 outputs on the Nth clock cycle, where N is the total delay programmed. |
| LCO-10 | $\begin{aligned} & 20-26, \\ & 41-44 \end{aligned}$ | 1 | Length Control Inputs. These inputs are used to specify the number of clock cycles of delay between the DIO-9 inputs and the DO0-9 outputs. An integer value between 0 and 1279 is placed on the LCO-10 inputs, and the total delay length ( N ) programmed is the LC0-10 value plus 2 . In order to properly load an active length control word, the value must be presented to the LCO-10 inputs and LCEN\# must be asserted during an active clock edge selected by CLKSEL. |
| LCEN\# | 6 | I | Length Control Enable. LCEN\# is used in conjuction with LC0-10 and CLK to load a new length control word. An 11-bit value is loaded on the LCO-10 inputs, LCEN\# is asserted, and the next selected clock edge will load the new count value. Since this operation is synchronous, LCEN\# must meet the specified setup/hold times with respect to CLK for proper operation. |
| OE\# | 19 | 1 | Output Enable. This input controls the state of the DOO-9 output port. A low on this control line enables the port for output. When OE\# is high, the output drivers are in the high impedance state. Internal latching or transfer of data is not affected by this input. |
| MODSEL | 40 | I | Mode Select. This input is used to control the mode of operation of the HSP9501. A low on MODSEL causes the device to latch new data at the DIO-9 inputs on every clock cycle, and operate as a programmable pipeline register. When MODSEL is high, the HSP9501 is in the recirculate mode, and will operate as a programmable length circular buffer. This control signal may be used in a synchronous fashion during device operation, however, care must be taken to ensure the required setup/hold times with respect to CLK are met. |
| CLKSEL | 5 | 1 | Clock Select Control. This input is used to determine which edge of the CLK signal is used for controlling all internal events. A low on CLKSEL selects the negative going edge, therefore, all setup, hold, and output delay times are with respect to the negative edge of CLK. When CLKSEL is high, the positive going edge is selected and all synchronous timing is with respect to the positive edge of the CLK signal. |
| CLKEN\# | 2 | I | Clock Enable. This control signal can be used to enable or disable the CLK input. When low, the CLK input is enabled and will operate in a normal fashion. A high on CLKEN\# will disable the CLK input and will "hold" all internal operations and data. This control signal may also be used in a synchronous fashion, however, setup and hold requirements with respect to CLK must be met for proper device operation. This signal takes effect on the clock following the one that latches it in. |

## Functional Description

The HSP9501 is a 10 -bit wide programmable length data buffer. The length of delay is programmable from 2 to 1281 delays in single delay increments.

Data into the delay line may be selected from the data input bus (DIO-9) or as recirculated output, depending on the state of the mode select (MODSEL) control input.

## Mode Select

The MODSEL control pin selects the source of the data moving into the delay line. When MODSEL is low, the data input bus (DIO-9) is the source of the data. When MODSEL is high, the output of the HSP9501 is routed back to the input to form a circular buffer.
The MODSEL control line is latched at the input by the CLK signal. The edge which latches this control signal is determined by the CLKSEL control line. In either case, the MODSEL line is latched on one edge of the CLK signal with the following edge moving data into and through the HSP9501. Refer to the functional timing waveforms for specific timing references.

## Clock Select Logic

The clock select logic is provided to allow the use of positive or negative edge system clocks. The active edge of the CLK input to the HSP9501 is controlled through the use of the CLKSEL input.

When CLKSEL is low, the negative going edge of CLK is used to control all internal operations. A high on CLKSEL selects the positive going edge of CLK.

All synchronous timing (i.e. setup, hold and output propagation delay times are relative to the CLK edge selected by CLKSEL. Functional timing waveforms for each state of CLKSEL are provided (refer to timing waveforms for details).

## Delay Path Control

The HSP9501 buffer length is programmable from 2 to 1281 data words in one word increments. The minimum number of delays which can be programmed is two, consisting of the input and output buffer registers only.

The Length control inputs (LCO-10) are used to set the length of the programmable delay ram which can vary in length from 0 to 1279. The total length of the HSP9501 data buffer will then be equal to the programmed value on LCO-10 plus 2. The programmed delay is established by the 11-bit integer value of the LC0-10 inputs with LC10 as the MSB and LCO as the LSB.

For example,

| LC10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LCO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |

programs a length value of $2^{6}+2^{0}=65$. The total length of the delay will be $65+2$ or 67 delays.

Table 1 indicates several programming values. The decimal value placed on LCO-10 must not exceed 1279. Controlled operation with larger values is not guaranteed.

Values on LCO-10 are latched on the CLK edge selected by the CLKSEL control line, when LCEN\# is active. LCO-10 and LCEN\# must meet the specified setup and hold times relative to the selected CLK edge for proper device operation.

TABLE 1. LENGTH CONTROL PROGRAMMING EXAMPLES

| LC10 | LC9 | LS8 | LC7 | LC6 | LC5 | LC4 | LC3 | LC2 | LC1 | LCo |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{2}^{10}$ | $\mathbf{2}^{9}$ | $\mathbf{2}^{8}$ | $\mathbf{2}^{7}$ | $\mathbf{2}^{6}$ | $\mathbf{2}^{5}$ | $\mathbf{2}^{4}$ | $\mathbf{2}^{3}$ | $\mathbf{2}^{2}$ | $\mathbf{2}^{1}$ | $\mathbf{2}^{0}$ | PROGRAMMED <br> LENGTH | TOTAL <br> LENGTH <br> N |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 118 | 120 |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 808 | 810 |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1049 | 1051 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1279 | 1281 |

## Absolute Maximum Ratings

| $+8.0 \mathrm{~V}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
| Storage Temperature Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $6.65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |  |  |  |  |
| Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+150^{\circ} \mathrm{C}$ |  |  |  |  |  |
|  |  | Maximum Package Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.7W |  |  |  |
|  |  |  |  |  |  |
| $\theta_{\text {JA }}$..................................................................................................... 45.200 ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |  |  |  |  |  |
| Lead Temperature (Soldering, Ten Seconds) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+300^{\circ}{ }^{\circ} \mathrm{C}$ |  |  |  |  |  |
| CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. |  |  |  |  |  |

## Operating Conditions

$\qquad$
Operating Temperature Range
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
D.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Commercial)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V | $1 \mathrm{OH}=-4 \mathrm{~mA} \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=+4.0 \mathrm{~mA} \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=$ GND or $\mathrm{V}_{\text {CC }} \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }} \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Current | ICcsb | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V},$ $\text { Note } 2$ |
| Operating Power Supply Current | ICCOP | - | 125 | mA | $\begin{aligned} & f=25 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \text { Note } 1,2 \\ & \hline \end{aligned}$ |
| Input Capacitance | $\mathrm{CIN}^{\text {a }}$ | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, |
| Output Capacitance | Co | - | 10 | pF |  |

A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$, Commercial), (Note 4)

| PARAMETER | SYMBOL | -32 |  | -25 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCP | 31 | - | 40 | - | ns |  |
| Clock Pulse Width High | TPWH | 12 | - | 15 | - | ns |  |
| Clock Pulse Width Low | TPWL | 12 | - | 15 | - | ns |  |
| Data Input Setup Time | TDS | 10 | - | 12 | - | ns |  |
| Data Input Hold Time | TDH | 2 | - | 2 | - | ns |  |
| Output Enable Time | TENA | - | 20 | - | 25 | ns |  |
| Output Disable Time | TDIS | - | 24 | - | 25 | ns | Note 3 |
| CLKEN\# to Clock Setup | TES | 10 | - | 12 | - | ns |  |
| CLKEN\# to Clock Hold | TEH | 2 | - | 2 | - | ns |  |
| LCO-10 Setup Time | TLS | 10 | - | 13 | - | ns |  |
| LC0-10 Hold Time | TLH | 2 | - | 2 | - | ns |  |
| LCEN\# to Clock Setup | TLES | 10 | - | 13 | - | ns |  |
| LCEN\# to Clock Hold | TLEH | 2 | - | 2 | - | ns |  |
| MODSEL Setup Time | TMS | 10 | - | 13 | - | ns |  |
| MODSEL Hold Time | TMH | 2 | - | 2 | - | ns |  |
| Clock to Data Out | TOUT | - | 16 | - | 22 | ns |  |
| Output Hold from Clock | $\mathrm{T}^{\text {OH }}$ | 4 | - | 4 | - | ns |  |
| Rise, Fall Time | TRF | - | 6 | - | 6 | ns | Note 3 |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for ${ }^{1}$ CCOP is $5 \mathrm{~mA} / \mathrm{MHz}$.
2. Output load per test load circuit with switch open and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
4. A.C. Testing is performed as follows: Input levels: OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{N}$, Output load $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

Test Load Circuit


Switch S1 Open for $\mathrm{I}_{\mathrm{CCSB}}$ and $\mathrm{I}_{\mathrm{CCOP}}$ Tests

## Timing Waveforms



INTERNAL
CLOCK


CLKEN\# TIMING (CLKSEL = LOW)


OUTPUT RISE AND FALL TIMES


LENGTH CONTROL TIMING (CLKSEL = LOW)

Timing Waveforms (Continued)


FUNCTIONAL TIMING (CLKSEL $=$ HIGH)


LENGTH CONTROL TIMING (CLKSEL $=$ HIGH)
PAGE

## SIGNAL SYNTHESIZER DATA SHEETS

HSP45102 12-Bit Numerically Controlled Oscillator ..... 5-3
HSP45106 16-Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16-Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-47

## 12-Bit Numerically Controlled Oscillator

## Features

- 33MHz, 40MHz Versions
- 32-Bit Frequency Control
- BFSK, QPSK Modulation
- Serial Frequency Load
- 12-Bit Sine Output
- Offset Binary Output Format
- 0.009 Hz Tuning Resolution at $\mathbf{4 0 M H z}$
- Spurious Frequency Components <-69dBc
- Fully Static CMOS
- Low Cost


## Applications

- Direct Digital Synthesis
- Modulation


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP45102PC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead Plastic DIP |
| HSP45102PC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead Plastic DIP |
| HSP45102PI-33 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 28 Lead Plastic DIP |
| HSP45102PI-40 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 28 Lead Plastic DIP |
| HSP45102SC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead SOIC |
| HSP45102SC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 28 Lead SOIC |
| HSP45102SI-33 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 28 Lead SOIC |
| HSP45102SI-40 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 28 Lead SOIC |

## Description

The Harris HSP45102 is Numerically Controlled Oscillator with 32 bit frequency resolution and 12 bit output. With over 69 dB of spurious free dynamic range and worst case frequency resolution of 0.009 Hz , the NCO12 provides dramatic improvements in accuracy over other frequency synthesis solutions at a competitive price.

The frequency to be generated is selected from two frequency control words. A single control pin selects which word is used to determine the output frequency. Switching from one frequency to another occurs in one clock cycle, with a 6 clock pipeline delay from the time that the new control word is loaded until the new frequency appears on the output.

Two pins, P0-1, are provided for phase modulation. They are encoded and added to the top two bits of the phase accumulator to offset the phase in 900 increments.

The 13 bit output of the Phase Offset Adder is mapped to the sine wave amplitude via the Sine ROM. The output data format is offset binary to simplify interfacing to D/A converters. Spurious frequency components in the output sinusoid are less than -69 dBc .

The NCO12 has applications as a Direct Digital Synthesizer and modulator in low cost digital radios, satellite terminals, and function generators.

## Block Diagram



Pinout

|  | 28 PIN DIP, 28 PIN SOIC |
| ---: | :--- |
| TOP VIEW |  |

Pin Description

| NAME | PIN <br> NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| VCC | 8,22 |  | +5V power supply pin. |
| GND | $7,15,21$ |  | Ground |
| PO-1 | 19,20 | I | Phase modulation inputs (become active after a pipeline delay of four clocks). A phase shitt <br> of 0,90, 180, or 270 degrees can be selected (Table 1). |
| CLK | 16 | I | NCO clock. (CMOS level) |
| SCLK | 14 | 1 | This pin clocks the frequency control shift register. |
| SEL_L/M\# | 9 | 1 | A high on this input selects the least significant 32 bits of the 64 bit frequency register as <br> the input to the phase accumulator; a low selects the most significant 32 bits. |
| SFTEN\# | 10 | 1 | The active low input enables the shifting of the frequency register. |
| MSB/LSB\# | 11 | 1 | This input selects the shift direction of the frequency register. A low on this input shifts in the <br> data LSB first; a high shifts in the data MSB first. |
| ENPHAC\# | 12 | 1 | This pin, when low, enables the clocking of the Phase Accumulator. This input has a pipe- <br> line delay of four clocks. |
| SD | 13 | 1 | Data on this pin is shifted into the frequency register by the rising edge of SCLK when <br> SFTEN\# is low. |
| TXFR\# | 17 | 1 | This active low input is clocked onto the chip by CLK and becomes active after a pipeline <br> delay of four clocks. When low, the frequency control word selected by SEL_L/M\# is <br> transferred from the frequency register to the phase accumulator's input register. |
| LOAD\# | 18 | I | This input becomes active after a pipeline delay of five clocks. When low, the feedback in <br> the phase accumulator is zeroed. |
| OUTO-11 | $1-6,23-28$ | 0 | Output data. OUTO is LSB. Unsigned. |

All inputs are TTL level, with the exception of CLK.
\# sign designates active low signals.

## Functional Description

The NCO12 produces a 12 bit sinusoid whose frequency and phase are digitally controlled. The frequency of the sine wave is determined by one of two 32 bit words. Selection of the active word is made by SEL_L/M\#. The phase of the output is controlled by the two bit input PO-1, which is used to select a phase offset of $0^{\circ}, 90^{\circ}, 180^{\circ}$, or $270^{\circ}$.

As shown in the Block Diagram, the NCO12 consists of a Frequency Control Section, a Phase Accumulator, a Phase Offset Adder and a Sine ROM. The Frequency Control section serially loads the frequency control word into the frequency register. The Phase Accumulator and Phase Offset Adder compute the phase angle using the frequency control word and the two phase modulation inputs. The Sine ROM generates the sine of the computed phase angle. The format of the 12 bit output is offset binary.

## Frequency Control Section

The Frequency Control Section (Figure 1), serially loads the frequency data into a 64 bit, bidirectional shift register. The shift direction is selected with the MSB/LSB\# input. When this input is high, the frequency control word on the SD input is shifted into the register MSB first. When MSB/LSB\# is low the data is shifted in LSB first. The register shifts on the rising edge of SCLK when SFTEN\# is low. The timing of these signals is shown in Figure 2.

The 64 bits of the frequency register are sent to the Phase Accumulator Section where 32 bits are selected to control the frequency of the sinusoidal output.

## Phase Accumulator Section

The phase accumulator and phase offset adder compute the phase of the sine wave from the frequency control word and the phase modulation bits PO-1. The architecture is shown in Figure 1. The most significant 13 bits of the 32 bit phase accumulator are summed with the two bit phase offset to generate the 13 bit phase input to the Sine Rom. A value of 0 corresponds to $0^{\circ}$, a value of 1000 hexadecimal corresponds to a value of $180^{\circ}$.

The phase accumulator advances the phase by the amount programmed into the frequency control register. The output frequency is equal to $N^{*} F c l k / 232$, where $N$ is the selected 32 bits of the frequency control word. For example, if the control word is 20000000 hexadecimal and the clock frequency is 30 Mhz , then the output frequency would be Fclk/8 or 3.75 Mhz .

The frequency control multiplexer selects the least significant 32 bits from the 64 bit frequency control register when SEL_L/M\# is high, and the most significant 32 bits when SEL_L/M\# is low. When only one frequency word is desired, SEL_L/M\# and MSB/LSB\# must be either both high or both low. This is due to the fact that when a frequency control word is loaded into the shift register LSB first, it enters through the most significant bit of the register. After 32 bits have been shifted in, they will reside in the 32 most significant bits of the 64 bit register.
When TXFR\# is asserted, the 32 bits selected by the frequency control multiplexer are clocked into the phase accumulator input register. At each clock, the contents of this register are summed with the current contents of the accumulator to step to the new phase. The phase accumulator stepping may be inhibited by holding ENPHAC\# high. The phase accumulator may be loaded with the value in the input register by asserting LOAD\#, which zeroes the feedback to the phase accumulator.

The phase adder sums the encoded phase modulation bits PO-1 and the output of the phase accumulator to offset the phase by $0,90,180$ or 270 degrees. The two bits are encoded to produce the phase mapping shown in Table 1. This phase mapping is provided for direct connection to the in-phase and quadrature data bits for QPSK modulation.

TABLE 1

| PO-1 CODING |  |  |
| :---: | :---: | :---: |
| P1 | PO | PHASE SHIFT (DEGREES) |
| 0 | 0 | 0 |
| 0 | 1 | 90 |
| 1 | 0 | 270 |
| 1 | 1 | 180 |

## ROM Section

The ROM section generates the 12 bit sine value from the 13 bit output of the phase adder. The output format is offset binary and ranges from 001 to FFF hexadecimal, centered around 800 hexadecimal.


FIGURE 1. NCO-12 FUNCTIONAL BLOCK DIAGRAM


FIGURE 2A. FREQUENCY LOADING ENABLED BY SFTEN*


FIGURE 2B. FREQUENCY LOADING CONTROLLED BY SCLK


FIGURE 3. VO TIMING

## Absolute Maximum Ratings




```
Storage Temperature Range
-65
Junction Temperature
Maximum Package Power Dissipation (Commercial) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5W (DIP), 1.1W (SOIC)
Maximum Package Power Dissipation (Industrial). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.300
```



```
0jа . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50.10
Device Count
Lead Temperature (Soldering, Ten Seconds)
ESD Classification
.32,528 Transistors
Morature (Soldering, Ten Seconds) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +30000C
CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and
operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implled.
```


## Operating Conditions

```
Operating Voltage Range (Commercial, Industrial) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +4.75V to +5.25V
```



```
Operating Temperature Range (Industrial)
    -40}\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+8\mp@subsup{5}{}{\circ}\textrm{C
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\text {CC }}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | High Level Clock Input | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILC }}$ | Low Level Clock Input | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.6 | - | V | ${ }^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| ICCsB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| ICCOP | Operating Power Supply Current | - | 99 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, \mathrm{~V}_{I N}=V_{C C} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \text { Notes } 1 \text { and } 3 \end{aligned}$ |

## Capacitance $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$, Note 2)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, <br> All measurements are referenced <br> to device ground |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical 3. Output load per test load circuit with switch open and $C_{L}=40 p F$. rating for $I_{C C O P}$ is $3 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | -33 (33MHz) |  | -40 (40MHz) |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| TCP | Clock Period | 30 | - | 25 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | Clock High | 12 | - | 10 | - | ns |
| TCL | Clock Low | 12 | - | 10 | - | ns |
| TSW | SCLK High/Low | 12 | - | 10 | - | ns |
| TDS | Set-up Time SD to SCLK Going High | 12 | - | 12 | - | ns |
| TDH | Hold Time SD from SCLK Going High | 0 | - | 0 | - | ns |
| TMS | Set-up Time SFTEN\#, MSB/LSB\# to SCLK Going HGgh | 15 | - | 12 | - | ns |
| $\mathrm{T}_{\mathrm{MH}}$ | Hold Time SFTEN\#, MSB/LSB\# from SCLK Going High | 0 | - | 0 | - | ns |
| TSS | Set-up Time SCLK High to CLK Going High | 16 | - | 15 | - | ns, Note 2 |
| TPS | Set-up Time PO-1 to CLK Going High | 15 | - | 12 | - | ns |
| TPH | Hold Time PO-1 from CLK Going High | 1 | - | 1 | - | ns |
| TES | Set-up Time LOAD\#, TXFR\#, ENPHAC\#, SEL L/M\# to CLK Going High | 15 | - | 13 | - | ns |
| TEH | Hold Time LOAD\#, TXFR\#, ENPHAC\#, SEL__L/M\# from CLK Going High | 1 | - | 1 | - | ns |
| $\mathrm{T}_{\mathrm{OH}}$ | CLK to Output Delay | 2 | 15 | 2 | 13 | ns |
| TRF | Output Rise, Fall Time | 8 | - | 8 | - | ns, Note 3 |

NOTES

1. A.C. testing is performed as follows: Input levels (CL.K Input) 4.0 V and OV ; Input levels (all other inpuls) OV and 3.0V; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. If TXFR\# is active, care must be taken to not violate set-up and hold times as data from the shift registers may not have settled before CLK occurs.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
A.C. Test Load Circuit


Switch S 1 open for ${ }^{\mathrm{I}}$ CCSB and $\mathrm{I}_{\mathrm{CCOP}}$

## Waveforms



HSP45106

Features

- 25.6MHz, 33MHz Versions
- 32-Bit Center and Offset Frequency Control
- 16-Bit Phase Control
- 8 Level PSK Supported Through Three Pin Interface
- Simultaneous 16-Bit Sine and Cosine Outputs
- Output in Two's Complement or Offset Binary
- $<0.008 \mathrm{~Hz}$ Tuning Resolution at 33 MHz
- Serial or Parallel Outputs
- Spurious Frequency Components <-90dBc
- 16-Bit Microprocessor Compatlble Control Interface


## Applications

- Direct Digital Synthesis
- Quadrature Signal Generation
- Modulation - FM, FSK, PSK (BPSK, QPSK, 8PSK)
- Precision Signal Generation

Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP45106JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP45106.JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP45106GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP45106GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |

## 16-Bit Numerically Controlled Oscillator

## Description

The Harris HSP45106 is a high performance 16 -bit quadrature numerically controlled oscillator (NCO16). The NCO16 simplifies applications requiring frequency and phase agility such as frequency-hopped modems, PSK modems, spread spectrum communications, and precision signal generators. As shown in the block diagram, the HSP45106 is divided into a Phase/Frequency Control Section (PFCS) and a Sine/ Cosine Section.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The frequency resolution is 32 -bits, which provides for resolution of better than 0.008 Hz at 33 MHz . User programmable center frequency and offset frequency registers give the user the capability to perform phase coherent switching between two sinusoids of different frequencies. Further, a programmable phase control register allows for phase control of better than $0.006^{\circ}$. In applications requiring up to 8 -level PSK, three discrete inputs are provided to simplify implementation.

The output of the PFCS is a 32-bit phase which is input to the Sine/Cosine Section for conversion into sinusoidal amplitude. The outputs of the sine/cosine section are two 16-bit quadrature signals. The spurious free dynamic range of this complex vector is greater than 90 dBc .
For added flexibility when using the NCO16 in conjunction with DAC's, a choice of either parallel of serial outputs with either two's complement or offset binary encoding is provided. In addition, a synchronization signal is available which signals serial word boundaries.

## Block Diagram



Pinouts


## Pin Description

| NAME | PGA PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} \text { B5, D11, F1, } \\ \text { K7, K10 } \end{gathered}$ |  | +5 power supply pin. |
| GND | $\begin{gathered} \text { A9, D2, E10, } \\ \text { K4, L11 } \end{gathered}$ |  | Ground |
| C0-15 | $\begin{array}{\|l\|} \hline A 1-8, ~ B 3-4 \\ B 6-8, ~ C 5-7 \end{array}$ | 1 | Control input bus for loading phase, frequency, and timer data into the PFCS. CO is LSB. |
| AO-2 | A10, B9-10 | 1 | Address pins for selecting destination of $\mathbf{C O - 1 5}$ data (Table 2). |
| CS\# | E11 | 1 | Chip select (Active low). Enables data to be written into control registers by WR\#. |
| WR\# | E9 | 1 | Write enable (Active low). Data is clocked into the register selected by AO-2 on the rising edge of WR\# when CS\# is low. |
| CLK | K9 | I | Clock. All registers, except the control registers clocked with WR\#, are clocked (when enabled) by the rising edge of CLK. |
| ENPOREG\# | F10 | 1 | Phase Offset Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENPOREG\# enables the clocking of data into the Phase Offset Register. Allows ROM address to be updated regardless of ENPHAC\#. |
| ENOFREG\# | F9 | 1 | Offset Frequency Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENOFREG\# enables the clocking of data into the Offset Frequency Register. |
| ENCFREG\# | F11 | 1 | Center Frequency Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENCFREG\# enables the clocking of data into the Center Frequency Register. |
| ENPHAC\# | H11 | 1 | Phase Accumulator Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENPHAC\#enables the clocking of data into the Phase Accumulator Register. |
| ENTIREG\# | G11 | 1 | Timer Increment Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENTIREG\# enables the clocking of data into the Timer Increment Register. |
| INHOFR\# | G9 | 1 | Inhibit Offset Frequency Register Output (active low). Registered on chip by CLK. When active, after being clocked onto chip, INHOFR\# zeroes the data path from the Offset Frequency Register to the Frequency Adder. New data can be still clocked into the Offset Frequency Register. INHOFR\# does not affect the contents of the register. |
| INITPAC\# | J11 | 1 | Initialize Phase Accumulator (Active low). Registered on chip by CLK. Zeroes the feedback path in the Phase Accumulator. Does not clear the Phase Accumulator Register. |
| MODO-2 | $\begin{gathered} \text { B11, } \\ \text { C10-11 } \end{gathered}$ | 1 | Modulation Control Inputs. When selected with the PMSEL line, these bits add an offset of $0,45,90$, $135,180,225,270$, or 315 degrees to the current phase (i.e., modulate the output). The lower 13 bits of the phase control are set to zero. These bits are registered when the Phase Offset Register is enabled. |
| PMSEL | A11 | I | Phase Modulation Select input. Registered on chip by CLK. This input determines the source of the data clocked into the Phase Offset Register. When high, the Phase Input Register is selected. When low, the external modulation pins (MODO-2) control the three most significant bits of the Phase Offset Register and the 13 least significant bits are set to zero. |
| PACI\# | H10 | 1 | Phase Accumulator Carry Input (Active low). Registered on chip by CLK. |
| INITTAC\# | G10 | 1 | Initialize Timer Accumulator (Active low). This input is registered on chip by CLK. When active, after being clocked onto chip, INITTAC\# enables the clocking of data into the Timer increment Register, and also zeroes the feedback path in the Timer Accumulator. |
| TEST | D10 | I | Test select input. Registered on chip by CLK. This input is active high. When active, this input enables test busses to the outputs instead of the sine and cosine data. |
| PAR/SER\# | J10 | 1 | Parallel/Serial Output Select. This input is registered on chip by CLK. When low, the sine and cosine outputs are in serial mode. The output shift registers will load in new data after ENPHAC\# goes low and will start shifting the data out after ENPHAC\# goes high. When this input is high, the output registers are loaded every clock and no shifting takes place. |
| BINFMT\# | K11 | 1 | Format. This input is registered on chip by CLK. When low, the MSB of the SIN and COS are inverted to form an offset binary (unsigned) number. |
| OES\# | K2 | 1 | Three-state control for bits SINO-15. Outputs are enabled when OES\# is low. |
| OEC\# | J2 | 1 | Three-state control for bits COSO-15. Outputs are enabled when OEC\# is low. |
| TICO\# | B2 | 0 | Timer Accumulator Carry Output. Active low, registered. This output goes low when a carry is generated by the Timer Accumulator. |

## Pin Description (Continued)

| NAME | PGA PIN <br> NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| DACSTRB\# | L1 | 0 | DAC Strobe (Active low). In serial mode, this output will go low when the first bit of a new output <br> word is valid at the shift register output. This pin is active only in serial mode. |
| SINO-15 | J5-7, K3, <br> K5-6, K8, <br> L2-10 | 0 | Sine output data. When parallet mode is enabled, data is output on SINO-15. When serial mode is <br> enabled, output data bits are shifted out of SIN15 and SINO. The bit stream on SIN 15 is provided <br> MSB first while the bit stream on SINO is provided LSB first. |
| COS0-15 | B1, C1-2, <br> D1, E1-3, <br> F2-3, G1-3, <br> H1-2, J1, K1 | O | Cosine output data. When parallel mode is enabled, data is output on COSO-15. When serial <br> mode is enabled, output data bits are shifted out of COS15 and COSO. The bit stream on COS15 <br> is provided LSB first. |
| Index Pin | C3 |  | Used to align chip in socket or on circuit board. Must be left as a no connect in circuit. |

## Functional Description

The 16-bit Numerically Controlled Oscillator (NCO16) produces a digital complex sinusoid waveform whose frequency and phase are controlled through a standard microprocessor interface and discrete inputs. The NCO16 generates 16 -bit sine and cosine vectors at a maximum sample rate of 40 MHz . The NCO16 can be preprogrammed to produce a constant (CW) sine and cosine output for Direct Digital Synthesis (DDS) applications. Alternatively, the phase and frequency inputs can be updated in real time to produce a FM, PSK, FSK, or MSK modulated waveform. To simplify PSK generation, a 3 pin interface is provided to support modulation of up to 8 levels.

As shown in the Block Diagram, the NCO16 is comprised of a Phase and Frequency Control Section (PFCS) and Sine/ Cosine Section. The PFCS stores the phase and frequency control inputs and uses them to calculate the phase angle of a rotating complex vector. The Sine/Cosine Section performs a lookup on this phase and generates the appropriate amplitude values for the sine and cosine. These quadrature outputs may be configured as serial or parallel with either two's complement or offset binary format.

## Phase/Frequency Control Section

The phase and frequency of the quadrature outputs are controlled by the PFCS (Figure 1). The PFCS generates a 32 bit word which represents the instantaneous phase ( $\mathrm{Sin} / \mathrm{Cos}$ argument) of the sine and cosine waves being generated. This phase is incremented on the rising edge of each CLK by the preprogrammed amounts in the phase and frequency control registers. As the instantaneous phase steps from 0 through full scale ( $232-1$ ), the phase of the quadrature outputs proceeds from $0^{\circ}$ around the unit circle counter clockwise.

The PFCS is comprised of a Phase Accumulator Section, Phase Offset adder, Input Section, and a Timer Accumulator Section. The Phase Accumulator computes the instantaneous phase angle from user programmed values in the Center and Offset Frequency Registers. This angle is then fed into the Phase Offset adder where it is offset by the preprogrammed value in the Phase Offset Register. The input Section routes data from a microprocessor compatible control bus and discrete input signals into the appropriate configuration registers. The Timer Accumulator
supplies a pulse to mark the passage of a user programmed period of time.

## Input Section

The Input Section loads the data on $\mathrm{CO}-15$ into one of the seven input registers, the LSB and MSB Center Frequency Input Registers, the LSB and MSB Offset Frequency Registers, the LSB and MSB Timer Input Registers, and the Phase Input Register. The destination depends on the state of AO-2 when CS\# and WR\# are low (Table 1).

TABLE 1

| A2-O DECODING |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :--- | :---: |
| A2 | A1 | AO | CS\# | WR\# | FUNCTION |  |
| 0 | 0 | 0 | 0 | $\uparrow$ | Load Ieast significant bits of <br> Center Frequency input. |  |
| 0 | 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Center Frequency input. |  |
| 0 | 1 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> Offset Frequency input. |  |
| 0 | 1 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Offset Frequency input. |  |
| 1 | 0 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> Timing Interval input. |  |
| 1 | 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Timing Interval input. |  |
| 1 | 1 | 0 | 0 | $\uparrow$ | Load Phase Register |  |
| 1 | 1 | 1 | 0 | $\uparrow$ | Reserved |  |
| X | X | x | 1 | x | Input Disabled |  |

Once the input registers have been loaded, the control inputs ENCFREG\#, ENOFREG\#, ENTIREG\#, ENCTIREG\#, and ENPOREG\# will allow the input registers to be downloaded to the PFCS control registers with the input CLK. The control inputs are latched on the rising edge of CLK and the control registers are updated on the rising edge of the following CLK. For example, to load the Center Frequency Register, the data is loaded into the LSB and MSB Center Frequency Input Register, and ENCFREG\# is set to zero; the next rising edge of CLK will pass the registered version of ENCFREG\#, R.ENCFREG\#, to the

clock enable of the Center Frequency Register; this register then gets loaded on the following rising edge of CLK. The contents of the input registers are downloaded to the control registers every clock if the control inputs are enabled.

## Phase Accumulator Section

The Phase Accumulator adds the 32 bit output of the Frequency Adder with the contents of a 32 bit Phase Accumulator Register on every clock cycle. When the sum causes the adder to overflow, the accumulation continues with the least significant 32 bits of the result.

Initializing the Phase Accumulator Register is done by putting a low on the INITPAC\# and ENPHAC\# lines. This zeroes the feedback path to the accumulator, so that the register is loaded with the current value of the Frequency Adder on the next clock.

The frequency of the quadrature outputs is based on the number of clock cycles required to step from 0 to full scale. The number of steps required for this transition depends on the phase increment calculated by the frequency adder. For example, if the Center and Offset Frequency registers are programmed such that the output of the Frequency Adder is 40000000 hex, the Phase Accumulator will step the phase from 0 to 360 degrees every 4 clock cycles. Thus, for a 30 MHz CLK, the quadrature outputs will have a frequency of $30 / 4 \mathrm{MHz}$ or 7.5 MHz . In general, the frequency of the quadrature output is determined by $\mathrm{N} \times \mathrm{FCLK} / 2^{32}$, where N is the output of the Frequency Adder and FCLK is the frequency of CLK.

The Frequency Adder sums the contents of both the Center and Offset Frequency Registers to produce a phase increment. By enabling INHOFR\#, the output of the Offset Frequency Register is disabled so that the output frequency is determined from the Center Frequency Register alone. For BFSK modems, INHOFR\# can be asserted/ de-asserted to toggle the quadrature outputs between two programmed frequencies. Note: enabling/disabling INHOFR\# preserves the contents of the Offset Frequency Register.

## Phase Offset Adder

The output of the Phase Accumulator goes to the Phase Offset Adder, which adds the 16 bit contents of the Phase Offset Register to the 16 MSB's of the phase. The resulting 32-bit number forms the instantaneous phase which is fed to the Sine/Cosine Section.
The user has the option of loading the Phase Offset Registers with the contents of the Phase Input Register or the MODO-2 inputs depending on the state of PMSEL. When PMSEL is high, the contents of the Phase Input Register are loaded. If PMSEL is low, MODO-2 encode the upper 3 bits of the Phase Offset Register while the lower 13 bits are cleared. The MODO-2 inputs simplify PSK modulation by providing a 3 input interface to phase modulate the carrier as shown in Table 2. The control input ENPOREG\# acts as a clock enable and must be low to enable clocking of data into the Phase Offset Register.

TABLE 2

| MOD2-0 DECODING |  |  |  |
| :---: | :---: | :---: | :---: |
| MOD2 | MOD1 | MODO | PHASE SHIFT <br> (DEGREES) |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 45 |
| 0 | 1 | 0 | 90 |
| 0 | 1 | 1 | 135 |
| 1 | 0 | 0 | 270 |
| 1 | 0 | 1 | 315 |
| 1 | 1 | 0 | 180 |
| 1 | 1 | 1 | 225 |

Timer Accumulator Section
The Timer Accumulator consists of a register which is incremented on every clock. The amount by which it increments is loaded into the Timer Increment Input Registers and is latched into the Timer Increment Register on rising edges of CLK while ENTIREG\# is low. The output of the Timer Accumulator is the accumulator carry out, TICO\#. TICO\# can be used as a timer to enable the periodic sampling of the output of the NCO-16. The number programmed into this register equals ( $232 \times$ CLK period)/ (desired time interval).

## Sine/Cosine Section

The Sine/Cosine Section (Figure 2) converts the instantaneous phase from the PFCS Section into the appropriate amplitude values for the sine and cosine outputs. It takes the most significant 20 bits of the PFCS output and passes them through a Sine/Cosine look up to form the 16 bit quadrature outputs. The sine and cosine values are computed to reduce the amount of ROM needed. The magnitude of the error in the computed value of the complex vector is less than -90.2 dB . The error in the sine or cosine alone is approximately 2 dB better. The 20 bit phase word maps into $2 \pi$ radians so that the angular resolution is $(2 \pi) / 2^{20}$. An address of zero corresponds to 0 radians and an address of hex FFFFF corresponds to $2 \pi-\left((2 \pi) / 2^{20}\right)$ radians. The outputs of the Sine/Cosine Section are two's complement sine and cosine values. The ROM contents have been scaled by $\left(2^{16-1}\right) /\left(2^{16+1}\right)$ for symmetry about zero.
To simplify interfacing with D/A converters, the format of the sine/cosine outputs may be changed to offset binary by enabling BINFMT\#. When BINFMT\# is enabled, The MSB of the Sine and Cosine outputs (SIN15 and COS15 when the outputs are in parallel mode) are inverted. Depending upon the state of BINFMT\#, the output is centered around midscale and ranges from 8001 H to 7FFFH (two's complement mode) or 0001 H to FFFFH (offset binary mode).
Serial output mode may is chosen by enabling PAR/SER\#. In this mode the user loads the output shift registers with Sine/Cosine ROM output by enabling ENPHAC\#. After ENPHAC\# goes inactive the data is shifted out serially. For
example, to clock out one 16 bit sine/cosine output, ENPHAC\# would be active for one cycle to load the output shift register, and would then go inactive for the following 15 cycles to clock the remaining bits out. Output bit streams are provided in formats with either MSB first or LSB first. The MSB first format is available on the SIN15 and COS15 output pins. The LSB first format is available on the SINO and COS0 output pins. In MSB first format, zero's follow the LSB if a new output word is not loaded into the shift register. In LSB first format, the sine extension bit follows the MSB if a
new data word is not loaded. The output signal DACSTRB\# is provided to signal the first bit of a new output word is valid (Figure 3). Note: all unused pins of SINO-15 and COSO-15 should be left floating.

A test mode is supplied which enables the user to access the phase input to the Sine/Cosine ROM. If TEST and PAR/ SER\# are both high, the 28 MSB's of the phase input to the Sine/ Cosine Section are made available on SINO-15 and COS4-15. The SINO-15 outputs represent the MSW of the address.


FIGURE 2. SINE/COSINE BLOCK DIAGRAM


FIGURE 3. SERIAL OUTPUT VO TIMING DIAGRAM

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation | 2.3 W (PLCC), 2.9W (PGA) |
| $\theta_{\text {jc }}$ | $11.3{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $10.0^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
|  | $.34 .0^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $36^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Component Count | . 75,000 Transistors |
| Junction Temperature | $+150^{\circ} \mathrm{C}$ (PLCC),$+175^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering, Ten Seconds) | .$+300^{\circ} \mathrm{C}$ |
| ESD Classification | . . Class 1 |

## Operating Conditions

```
Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +4.75V to +5.25V
```



## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $V_{C C}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage | - | 0.8 | v | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | High Level Clock Input | 3.0 | - | v | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILC }}$ | Low Level Clock Input | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.6 | - | V | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{l}^{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{C C}=5.25 \mathrm{~V}$ |
| 10 | 1/O Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.25 V \end{aligned}$ |
| ${ }^{\prime} \mathrm{CcsB}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| ${ }^{1} \mathrm{CCOP}$ | Operating Power Supply Current | - | 180 | mA | $f=25.6 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=V_{\mathrm{CC}} \text { or GND }$ $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \text {, Notes } 1 \text { and } 3$ |

## Capacitance ( $T_{A}=+25^{\circ} \mathrm{C}$, Note 2)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance | - | 10 | pF | FREQ $=1$ MHz, $\mathrm{V}_{\text {CC }}=$ Open, <br> All measurements are referenced <br> to device ground |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical 3. Output load per test load circuit with switch open and $C_{L}=40 p{ }^{2}$ rating for $I_{\text {CCOP }}$ is $7 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | 25.6 MHz |  | 33 MHz |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| $\mathrm{T}_{\mathrm{CP}}$ | CLK Period | 39 | - | 30 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | CLK High | 15 | - | 12 | - | ns |
| TCL | CLKLow | 15 | - | 12 | - | ns |
| TWP | WR\# Period | 39 | - | 30 | - | ns |
| TWH | WR\# High | 15 | - | 12 | - | ns |
| TWL | WR\# Low | 15 | - | 12 | - | ns |
| TAWS | Set-up Time AO-2, CS\# to WR\# Going High | 13 | - | 13 | - | ns |
| $\mathrm{T}_{\text {AWH }}$ | Hold Time AO-2, CS\# from WR\# Going High | 1 | - | 1 | - | ns |
| TCWS | Set-up Time CO-15 to WR\# Going High | 15 | - | 15 | - | ns |
| TCWH | Hold Time C0-15 from WR\# Going High | 0 | - | 0 | - | ns |
| TwC | Set-up Time WR\# High to CLK High | 16 | - | 12 | - | ns, Note 2 |
| TMCS | Set-up Time MODO-2 to CLK Going High | 15 | - | 15 | - | ns |
| $\mathrm{T}_{\mathrm{MCH}}$ | Hold Time MODO-2 from CLK Going High | 0 | - | 0 | - | ns |
| TECS | Set-up Time ENPOREG\#, ENOFREG\#,ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST,PAR/SER\#, PACI\#, INITTAC\# to CLK Going High | 12 | - | 12 | - | ns |
| TECH | Hold Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST,PAR/SER\# , PACI\#, INITTAC\# from CLK Going High | 0 | - | 0 | - | ns |
| TDO | CLK to Output Delay SINO-15, COSO-15, TICO\# | - | 18 | - | 15 | ns |
| TDSO | CLK to Output Delay DACSTRB\# | 2 | 18 | 2 | 15 | ns |
| ToE | Output Enable Time | - | 12 | - | 12 | ns |
| Tod | Output Disable Time | - | 15 | - | 15 | ns, Note 3 |
| TRF | Output Rise, Fall Time | - | 8 | - | 8 | $n \mathrm{n}$, Note 3 |

NOTES:

1. A.C.testing is performed as follows: Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) oV and 3.0V; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with switch closed and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq$ 1.5 V .
2. If ENOFREG\#, ENCFREG\#, ENTIREG\#, OR ENPOREG\# are active care must be taken to not violate set-up and hoid times to these registers when writing data into the chip via the $\mathbf{C 0}-15$ port.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
A.C. Test Load Circuit



OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES


# 16-Bit Numerically Controlled Oscillator 

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and Is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- 25.6 MHz Clock Rate
- 32-Bit Center and Offset Frequency Control
- 16-Bit Phase Control
- 8 Level PSK Supported Through Three Pin Interface
- Simultaneous 16-Bit Sine and Cosine Outputs
- Output in Two's Complement or Offset Binary
- $<0.006 \mathrm{~Hz}$ Tuning Resolution at $\mathbf{2 5 . 6 M H z}$
- Serial or Parallel Outputs
- Spurious Frequency Components < -90dBc
- 16-BIt Microprocessor Compatible Control Interface


## Applications

- Direct Digital Synthesis
- Quadrature Signal Generation
- Modulation - FM, FSK, PSK (BPSK, QPSK, 8PSK)
- Precision Signal Generation


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP45106GM-25 $/ 883$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The Harris HSP45106/883 is a high performance 16-bit quadrature numerically controlled oscillator (NCO16). The NCO16 simplifies applications requiring frequency and phase agility such as frequency-hopped modems, PSK modems, spread spectrum communications, and precision signal generators. As shown in the block diagram, the HSP45106/883 is divided into a Phase/Frequency Control Section (PFCS) and a Sine/Cosine Section.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The frequency resolution is 32 -bits, which provides for resolution of better than 0.006 Hz at 25.6 MHz . User programmable center frequency and offset frequency registers give the user the capability to perform phase coherent switching between two sinusoids of different frequencies. Further, a programmable phase control register allows for phase control of better than $0.006^{\circ}$. In applications requiring up to 8 level PSK, three discrete inputs are provided to simplify implementation.

The output of the PFCS is a 32-bit phase argument which is input to the sine/cosine section for conversion into sinusoidal amplitude. The outputs of the sine/cosine section are two 16 -bit quadrature signals. The spurious free dynamic range of this complex vector is greater than 90 dBc .

For added flexibility when using the NCO16 in conjunction with DAC's, a choice of either parallel of serial outputs with either two's complement or offset binary encoding is provided. In addition, a synchronization signal is available which signals serial word boundaries.

## Block Diagram



## Absolute Maximum Ratings



## Rellability Information

| Thermal Resistance Ceramic PGA Package . | $\begin{gathered} \theta_{\mathrm{ja}} \\ 36.0^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ | $\begin{gathered} \theta_{\mathrm{jc}} \\ 11.6^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic PGA Package . |  |  |
| Gate Count |  | ,750 Gat |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP45106/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{OL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 V \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{IHC}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ${ }^{\text {i ccseb }}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { (Note 4) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & \mathrm{f}=25.6 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(\text { Notes } 2,4) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 205 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.
4. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

## Specifications HSP45106/883

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested.

| PARAMETERS | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | $\frac{\text { LIMITS }}{-25}$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | 39 | - | ns |
| CLK High | ${ }^{\text {T }} \mathrm{CH}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| CLKLow | ${ }^{\text {T }} \mathrm{CL}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125{ }^{\circ} \mathrm{C}$ | 15 | - | ns |
| WR\# Period | TWP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | ns |
| WR\# High | TWH |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| WR\# Low | TWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Set-up Time AO-2, CS\# to WR\# Going High | TAWS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | 13 | - | ns |
| Hold Time AO-2, CS\# from WR\# Going High | $\mathrm{T}_{\text {AWH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2 | - | ns |
| Set-up Time CO-15 to WR\# Going High | Tcws |  | 9,10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Hold Time C0-15 from WR\# Going High | TCWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| Set-up Time WR\# High to CLK High | TWC | Note 3 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | - | ns |
| Set-up Time MODO-2 to CLK Going High | TMCS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Hold Time MODO-2 from CLK Going High | $\mathrm{T}_{\mathrm{MCH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| Set-up Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST, PAR/SER\#,PACI\#, INITTAC\# to CLK Going High | TECS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | ns |
| Hold Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST, PAR/SER\#, PACI\#, INITTAC\# from CLK Going High | TECH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| CLK to Output Delay SINO-15, COSO-15, TICO\# | ${ }^{\text {T DO }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 18 | ns |
| CL.K to Output Delay DACSTRB\# | TDSO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | 18 | ns |
| Output Enable Time . | TOE | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 12 | ns |

NOTES:

1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven to 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0V. Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. If ENOFRCTL\#, ENCFRCTL\#, ENTICTL\# or ENPHREG\# are active, care must be taken to not violate set-up and hoid times to these registers when writing data into the chip via the $\mathrm{CO}-15$ port.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25.6MHz) |  |  |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cl}_{\mathrm{IN}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Open, } \\ & \mathrm{f}=1 \mathrm{MHz}, \mathrm{All} \end{aligned}$ measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Output Capacitance | COUT | $\begin{aligned} & V_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, A l l \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Output Disable Delay | ToEZ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 15 | ns |
| Output Rise Time | TOR | From 0.8V to 2.0V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | ns |
| Output Fall Time | TOF | From 2.0V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | ns |

## NOTES:

1. Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

## HSP45106/883

Burn-In Circuit
HSP45106/883 PIN GRID ARRAY (PGA)


|  |  | 11 | 10 | 9 | 7 |  | 5 | 2 | 1 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{array}{l\|l} \text { PGA } \\ \text { PIN } \end{array}\right.$ | PIN NAME | BURN-IN SIGNAL | $\left\lvert\, \begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}\right.$ | PIN NAME | BURN-IN SIGNAL | $\begin{array}{\|l} \text { PGA } \\ \text { PIN } \end{array}$ | PIN NAME | BURN-IN SIGNAL | $\begin{array}{\|l\|l\|} \text { PGA } \\ \text { PIN } \end{array}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| A1 | CO | F7 | B11 | MOD1 | F13 | F9 | ENOFREG\# | F8 | K2 | OES\# | F14 |
| A2 | C2 | F7 | C1 | COS13 | $\mathrm{V}_{\mathrm{CC}} / 2$ | F10 | ENPOREG\# | F4 | K3 | SIN15 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| A3 | C3 | F7 | C2 | COS15 | $\mathrm{v}_{\mathrm{CC} / 2}$ | F11 | ENCFREG\# | F7 | K4 | GND | GND |
| A4 | C5 | F8 | C5 | C6 | F8 | G1 | COS5 | $\mathrm{V}_{\mathrm{CC}} / 2$ | K5 | SIN10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| A5 | C7 | F8 | C6 | C9 | F10 | G2 | $\cos 4$ | $\mathrm{v}_{\mathrm{CC} / 2}$ | K6 | SIN8 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| A6 | C8 | F10 | C7 | C10 | F10 | G3 | COS6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K7 | $V_{C C}$ | $V_{C C}$ |
| A7 | C11 | F10 | C10 | MODO | F12 | G9 | INHOFR\# | F11 | K8 | SIN2 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| A8 | C14 | F11 | C11 | MOD2 | F14 | G10 | INITTAC\# | F13 | K9 | CLK | FO |
| A9 | GND | GND | D1 | COS12 | $\mathrm{V}_{\mathrm{CC}} / 2$ | G11 | ENTIREG\# | F12 | K10 | $V_{C C}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| A10 | AO | F8 | D2 | GND | GND | H1 | cos3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | BINFMT\# | F6 |
| A11 | PMSEL | F14 | D10 | TEST | F14 | H2 | COS2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L1 | DACSTRB\# | $\mathrm{v}_{\mathrm{cc} / 2}$ |
| B1 | COS14 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D11 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | H10 | PACI\# | F11 | L2 | SIN14 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B2 | TICO\# | $\mathrm{V}_{\mathrm{CC}} / 2$ | E1 | COS9 | $\mathrm{V}_{\mathrm{CC}} / 2$ | H11 | ENPHAC\# | F10 | L3 | SIN13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B3 | C1 | F7 | E2 | COS10 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J1 | COS 1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L4 | SIN12 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B4 | C4 | F8 | E3 | cos11 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J2 | OEC\# | F14 | L5 | SIN9 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B5 | $\mathrm{V}_{\text {CC }}$ | $V_{C C}$ | E9 | WR\# | F4 | J5 | SIN11 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L6 | SIN4 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B6 | C13 | F11 | E10 | GND | GND | J6 | SIN7 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L7 | SIN5 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B7 | C12 | F11 | E11 | CS\# | F6 | $J 7$ | SIN6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L8 | SIN3 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B8 | C15 | F11 | F1 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {CC }}$ | J10 | PAR/SER\# | F13 | L9 | SIN1 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B9 | A1 | F7 | F2 | COS8 | $\mathrm{VCC} / 2$ | J11 | INITPAC\# | F12 | L10 | SINO | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B10 | A2 | F10 | F3 | COS7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K1 | coso | $\mathrm{V}_{\mathrm{CC} / 2}$ | L11 | GND | GND |

## NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $\mathbf{4 7 \mathrm { K } \Omega}( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND .
3. $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, \mathrm{~F} 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2,40 \%-60 \%$ Duty Cycle.
6. Input voltage limits: $V_{I L}=0.8 \mathrm{~V}$ Max $\quad V_{I H}=4.5 \mathrm{~V} \pm 10 \%$

## Die Characteristics

DIE DIMENSIONS:
WORST CASE CURRENT DENSITY: $0.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
$251 \times 240 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$ Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

## Metallization Mask Layout



# Numerically Controlled Oscillator/Modulator 

## Features

- NCO and CMAC on One Chip
- $15 \mathrm{MHz}, 25.6 \mathrm{MHz}, 33 \mathrm{MHz}$ Versions
- 32-Bit Frequency Control
- 16-Bit Phase Modulation
- 16-Bit CMAC
- 0.008 Hz Tuning Resolution at 33 MHz
- Spurious Frequency Components <-90dBc
- Fully Static CMOS


## Applications

- Frequency Synthesis
- Modulation - AM, FM, PSK, FSK, QAM
- Demodulation, PLL
- Phase Shifter
- Polar to Cartesian Conversions


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :--- | :--- |
| HSP45116VC-15 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 160 Lead MQFP |
| HSP45116VC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 160 Lead MQFP |
| HSP45116VC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 160 Lead MQFP |
| HSP45116GC-15 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 145 Lead PGA |
| HSP45116GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 145 Lead PGA |
| HSP45116GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 145 Lead PGA |
| HSP45116TM-15 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 156 Lead TAB |
| HSP45116TM-25 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 156 Lead TAB |
| HSP45116AVC-52 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 160 Lead MQFP |

## Description

The Harris HSP45116 combines a high performance quadrature numerically controlled oscillator (NCO) and a high speed 16-bit Complex Multiplier/Accumulator (CMAC) on a single IC. This combination of functions allows a complex vector to be multiplied by the internally generated (cos, $\sin$ ) vector for quadrature modulation and demodulation. As shown in the block diagram, the HSP45116 is divided into three main sections. The Phase/Frequency Control Section (PFCS) and the Sine/Cosine Section together form a complex NCO. The CMAC multiplies the output of the Sine/ Cosine Section with an external complex vector.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The phase resolution of the PFCS is 32 -bits, which results in frequency resolution better than 0.008 Hz at 33 MHz . The output of the PFCS is the argument of the sine and cosine. The spurious free dynamic range of the complex sinusoid is greater than 90 dBc .

The output vector from the Sine/Cosine Section is one of the inputs to the Complex Multiplier/Accumulator. The CMAC multiplies this (cos, sin) vector by an external complex vector and can accumulate the result. The resulting complex vectors are available through two 20-bit output ports which maintain the 90dB spectral purity. This result can be accumulated internally to implement an accumulate and dump filter.

A quadrature down converter can be implemented by loading a center frequency into the Phase/Frequency Control Section. The signal to be downconverted is the Vector Input of the CMAC, which multiplies the data by the rotating vector from the Sine/Cosine Section. The resulting complex output is the down converted signal.

The pinout for the TAB package can be obtained by referring to the Metallization Mask Layout of the HSP45116/883 data sheet.

## Block Diagram



Pinouts
45 PIN PGA
TOP VIEW


## Pinouts (Continued)



NOTE:

1. Pin 75 functions as the round enable (RND\#) on the HSP45116A. Pin 75 is $\mathrm{V}_{\mathrm{CC}}$ on the HSP45116.

## Pin Description

| NAME | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | A1, A9, A15, G1, J15, Q1, Q7, Q15 |  | +5 Power supply input |
| GND | $\begin{aligned} & \text { A8, A14, B1, H1, } \\ & \text { H15, P15, Q2, Q8 } \end{aligned}$ |  | Power supply ground input |
| C0-15 | $\begin{gathered} \mathrm{N} 8-11, \mathrm{P} 8-13 \\ \mathrm{Q} 9-14 \end{gathered}$ | 1 | Control input bus for loading phase and frequency data into the PFCS. C15 is the MSB. |
| ADO-1 | N7, P7 | 1 | Address pins for selecting destination of $\mathrm{CO-15}$ data |
| CS\# | P6 | 1 | Chip select (Active Low) |
| WR\# | Q6 | 1 | Write enable. Data is clocked into the register selected by ADO-1 on the rising edge of WR \# when the CS\# line is low. |
| CLK | Q5 | 1 | Clock. All registers, except the control registers clocked with WR\#,are clocked (when enabled) by the rising edge of CLK. |
| ENPHREG\# | M1 | 1 | Phase register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENPHREG\# enables the clocking of data into the phase register. |
| ENOFREG\# | N1 | 1 | Frequency offset register enable. (Active Low) Registered on chip by CLK. When active, after being clocked onto chip, ENOFREG\# enables clocking of data into the frequency offset register. |
| ENCFREG\# | N5 | 1 | Center frequency register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENCFREG\# enables clocking of data into the center frequency register. |
| ENPHAC\# | Q3 | 1 | Phase accumulator register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENPHAC\# enables clocking of the phase accumulator register. |
| ENTIREG\# | P5 | 1 | Time interval control register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENTIREG\# enables clocking of data into the time accumulator register. |
| ENI\# | Q4 | I | Real and imaginary data input register (RIR, IIR) enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENI\# enables clocking of data into the real and imaginary input data register. |
| MODPI/ 2PI\# | N6 | 1 | Modulo $\pi / 2 \pi$ select. When low, the Sine and Cosine ROMs are addressed modulo $2 \pi$ (360 degrees). When high, the most significant address bit is held low so that the ROMs are addressed modulo $\pi$ ( 180 degrees). This input is registered on chip by clock. |
| CLROFR\# | P4 | 1 | Frequency offset register output zero. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, CLROFR\# zeros the data path from the frequency offset register to the frequency adder. New data can still be clocked into the frequency offset register; CLROFR\# does not affect the contents of the register. |
| LOAD\# | N4 | 1 | Phase accumulator load control. (Active low) Registered on chip by CLK. Zeroes feedback path in the phase accumulator without clearing the phase accumulator register. |
| MODO-1 | M3, N3 | 1 | External modulation control bits. When selected with the PMSEL line, these bits add a 0,90 , 180, or 270 degree offset to the current phase in the phase accumulator. The lower 14 bits of the phase control path are set to zero. <br> These bits are loaded into the phase register when ENPHREG\# is low. |
| PMSEL | P3 | 1 | Phase modulation select line. This line determines the source of the data clocked into the phase register. When high, the phase control register is selected. When low, the external modulation pins (MODO-1) are selected for the most significant two bits and the least significant two bits and the least significant 14 bits are set to zero. This control is registered by CLK. |
| RBYTILD\# | L3 | 1 | ROM bypass, timer load. Active low, Registered by CLK. This input bypasses the sine/ cosine ROM so that the 16 bit phase adder output and lower 16 bits of the phase accumulator go directly to the CMAC's sine and cosine inputs, respectively. It also enables loading of the timer accumulator register by zeroing the feedback in the accumulator. |

## Pin Description (Continued)

| NAME | NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| PACI\# | P2 | I | Phase accumulator carry input. (Active low) A low on this pin causes the phase <br> accumulator to increment by one in addition to the values in the phase accumulator <br> register and frequency adder. |
| PACO\# | L13 | O | Phase accumulator carry output. Active low and registered by CLK. A low on this output <br> indicates that the phase accumulator has overflowed, i.e., the end of one sine/cosine cycle <br> has been reached. |
| TICO\# | P1 | O | Time interval accumulator carry output. Active low, registered by CLK. This output goes low <br> when a carry is generated by the time interval accumulator. This function is provided to time <br> out control events such as synchronizing register clocking to data timing. |
| RINO-18 | C1, C2, D1, D2, <br> E1-3, F1-3, <br> G2, G3, H2, | I | Real input data bus. This is the external real component into the complex multiplier. The bus <br> is clocked into the real input data register by CLK when ENi\# is asserted. Two's complement. |
| H3,J1-3, K1, K2 |  |  |  |

## Functional Description

The Numerically Controlled Oscillator/Modulator (NCOM) produces a digital complex sinusoid waveform whose amplitude, phase and frequency are controlled by a set of input command words. When used as a Numerically Controlled Oscillator (NCO), it generates 16 bit sine and cosine vectors at a maximum sample rate of 33 MHz . The NCOM can be preprogrammed to produce a constant (CW) sine and cosine output for Direct Digital Synthesis (DDS) applications. Alternatively, the phase and frequency inputs can be updated in real time to produce a FM, PSK, FSK, or MSK modulated waveform. The Complex Multiplier/ Accumulator (CMAC) can be used to multiply this waveform by an input signal for AM and QAM signals. By stepping the phase input, the output of the ROM becomes an FFT twiddle factor; when data is input to the Vector Inputs (see Block Diagram), the NCOM calculates an FFT butterfly.

As shown in the Block Diagram, the NCOM consists of three parts: Phase and Frequency Control Section (PFCS), Sine/Cosine Generator, and CMAC. The PFCS stores the phase and frequency inputs and uses them to calculate the phase angle of a rotating complex vector. The Sine/Cosine Generator performs a lookup on this phase and outputs the appropriate values for the sine and cosine. The sine and cosine form one set of inputs to the CMAC, which multiplies them by the input vector to form the modulated output.

## Phase and Frequency Control Section

The phase and frequency of the internally generated sine and cosine are controlled by the PFCS (Figure 1). The PFCS generates a 32 bit word that represents the current phase of the sine and cosine waves being generated: the Sine/ Cosine Argument. Stepping this phase angle from 0 through full scale (232-1) corresponds to the phase angle of a sinusoid starting at 00 and advancing around the unit circle counterclockwise. The PFCS automatically increments the phase by a preprogrammed amount on every rising edge of the external clock. The value of the phase step (which is the sum of the Center and Offset Frequency Registers) is:

$$
\text { Phase Step }=\frac{\text { Signal Frequency }}{\text { Clock Frequency }} \times 232
$$

The PFCS is divided into 2 sections: the Phase Accumulator uses the data on C0-15 to compute the phase angle that is the input to the Sine/Cosine Section (Sine/Cosine Argument); the Time Accumulator supplies a pulse to mark the passage of a preprogrammed period of time.

The Phase Accumulator and Time Accumulator work on the same principle: a 32 bit word is added to the contents of a 32 bit accumulator register every clock cycle; when the sum
causes the adder to overflow, the accumulation continues with the 32 bits of the adder going into the accumulator register. The overflow bit is used as an output to indicate the timing of the accumulation overflows. In the Time Accumulator, the overflow bit generates TICO\#, the Time Accumulator carry out (which is the only output of the Time Accumulator). In the Phase Accumulator, the overflow is inverted to generate the Phase Accumulator Carry Out, PACO\#.

The output of the Phase Accumulator goes to the Phase Adder, which adds an offset to the top 16 bits of the phase. This 32 bit number forms the argument of the sine and cosine, which is passed to the Sine/Cosine Generator.

Both accumulators are loaded 16 bits at a time over the C0-15 bus. Data on C0-15 is loaded into one of the three input registers when CS\# and WR\# are low. The data in the Most Significant Input Register and Least Significant Input Register forms a 32 bit word that is the input to the Center Frequency Register, Offset Frequency Register and Time Accumulator. These registers are loaded by enabling the proper register enable signal; for example, to load the Center Frequency Register, the data is loaded into the LS and MS Input Registers, and ENCFREG\# is set to zero; the next rising edge of CLK will pass the registered version of ENCFREG\#, R.ENCFREG\#, to the clock enable of the Center Frequency Register; this register then gets loaded on the following rising edge of CLK. The contents of the Input Registers will be continuously loaded into the Center Frequency Register as long as R.ENCFREG\# is low.

The Phase Register is loaded in a similar manner. Assuming PMSEL is high, the contents of the Phase Input Register is loaded into the Phase Register on every rising clock edge that R.ENPHREG is low. If PMSEL is low, MODO-1 supply the two most significant bits into the Phase Register (MOD1 is the MSB) and the least significant 14 bits are loaded with 0. MODO-1 are used to generate a Quad Phase Shift Keying (QPSK) signal (Table 2).

TABLE 1. ADO-1 DECODING

| AD1 | ADO | CS\# | WR\# | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> frequency input |
| 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> frequency input |
| 1 | 0 | 0 | $\uparrow$ | Load phase register |
| 1 | 1 | X | X | Reserved |
| X | X | 1 | X | Reserved |

The Phase Accumulator consists of registers and adders that compute the value of the current phase at every clock. It has three inputs: Center Frequency, which corresponds to the carrier frequency of a signal; Offset Frequency, which is the deviation from the Center Frequency; and Phase, which is a 16 bit number that is added to the current phase for

PSK modulation schemes. These three values are used by the Phase Accumulator and Phase Adder to form the phase of the internally generated sine and cosine.

The sum of the values in Center and Offset Frequency Registers corresponds to the desired phase increment (modulo $2^{32}$ ) from one clock to the next. For example, loading both registers with zero will cause the Phase Accumulator to add zero to its current output; the output of the PFCS will remain at its current value; i.e., the output of the NCOM will be a DC signal. If a hexadecimal 00000001 is loaded into the Center Frequency Control Register, the output of the PFCS will increment by one after every clock. This will step through every location in the Sine/Cosine Generator, so that the output will be the lowest frequency above DC that can be generated by the NCOM, i.e., the clock frequency divided by $2^{32}$. If the input to the Center Frequency Control Register is hex 80000000 , the PFCS will step through the Generator with half of the maximum step size, so that frequency of the output waveform will be half of the sample rate.

The operation of the Offset Frequency Control Register is identical to that of the Center Frequency Control Register; having two separate registers allows the user to generate an FM signal by loading the carrier frequency in the Center Frequency Control Register and updating the Offet Frequency Control Register with the value of the frequency offset - the difference between the carrier frequency and the frequency of the output signal. A logic low on CLROFR\# disables the output of the Offset Frequency Register without clearing the contents of the register.

TABLE 2. MODO-1 DECODE

| MOD1 | MODO | PHASE SHIFT (DEGREES) |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 90 |
| 1 | 0 | 270 |
| 1 | 1 | 180 |

Initializing the Phase Accumulator Register is done by putting a low on the LOAD\# line. This zeroes the feedback path to the accumulator, so that the register is loaded with the current value of the phase increment summer on the next clock.
The final phase value going to the Generator can be adjusted using MODPI/2PI\# to force the range of the phase to be 00 to $180^{\circ}$ (modulo $\pi$ ) or 00 to $360^{\circ}$ (modulo $2 \pi$ ). Modulo $2 \pi$ is the mode used for modulation, demodulation, direct digital synthesis, etc. Modulo $\pi$ is used to calculate FFTs. This is explained in greater detail in the Applications section.

The Phase Register adds an offset to the output of the Phase Accumulator. Since the Phase Register is only 16 bits, it is added to the top 16 bits of the Phase Accumulator.

The Time Accumulator consists of a register which is incremented on every clock. The amount by which it increments is loaded into the Input Registers and is latched into the Time Accumulator Register on rising edges of CLK while ENTIREG\# is low. The output of the Time Accumulator is the accumulator carry out, TICO\#. TICO\# can be used as a timer to enable the periodic sampling of the output of the NCOM. The number programmed into this register equals $232 \times$ CLK period/desired time interval. TICO\# is disabled and its phase is initialized by zeroing the feedback path of the accumulator with RBYTILD\#.

## Sine/Cosine Section

The Sine/Cosine Section (Figure 2) converts the output of the PFCS into the appropriate values for the sine and cosine. It takes the most significant 20 bits of the PFCS output and passes them through a look up table to form the 16 bit sine and cosine inputs to the CMAC.

R.RBYTLD
\#

## figure 2. SINE/COSINE SECTION

The 20 bit word maps into $2 \pi$ radians so that the angular resolution is $2 \pi / 2^{20}$. An address of zero corresponds to 0 radians and an address of hex FFFFF corresponds to $2 \pi-$ ( $2 \pi / 2^{20}$ ) radians. The outputs of the Generator section are 2's complement sine and cosine values. The sine and cosine outputs range from hexadecimal 8001, which represents negative full scale, to 7FFF, which represents positive full scale. Note that the normal range for two's complement numbers is 8000 to 7FFF; the output range of the SIN/COS generator is scaled by one so that it is symmetric about 0 .

The sine and cosine values are computed to reduce the amount of ROM needed. The magnitude of the error in the computed value of the complex vector is less than -90.2 dB . The error in the sine or cosine alone is approximately 2 dB better.

If RBYTILD\# is low, the output of the PFCS goes directly to the inputs of the CMAC. If the real and imaginary inputs of the CMAC are programmed to hex 7FFF and 0 respectively, then the output of the PFCS will appear on output bits 0 through 15 of the NCOM with the output multiplexers set to bring out the most significant bits of the CMAC output (OUTMUX $=00$ ). The most significant 16 bits out of the PFCS appears on IOUTO-15 and the least significant bits come out on ROUTO-15.

## Complex Multiplier/Accumulator

The CMAC (Figure 3) performs two types of functions: complex multiplication/accumulation for modulation and demodulation of digital signals, and the operations necessary to implement an FFT butterfly. Modulation and demodulation are implemented using the complex multiplier and its associated accumulator; the rest of the circuitry in this section, i.e., the complex accumulator, input shifters and growth detect logic are used along with the complex multiplier/accumulator for FFTs. The complex multiplier performs the complex vector multiplication on the output of the Sine/Cosine Section and the vector represented by the real and imaginary inputs RIN and IIN. The two vectors are combined in the following manner:
ROUT $=\operatorname{COS} \times$ RIN - SIN $\times$ IIN
IOUT $=\operatorname{COS} \times \operatorname{IIN}+\operatorname{SIN} \times \operatorname{RIN}$
RIN and IIN are latched into the input registers and passed through the shift stages. Clocking of the input registers is enabled with a low on ENI\#. The amount of shift on the latched data is programmed with $\mathrm{SHO}^{-1}$ (Table 3). The output of the shifters is sent to the CMAC and the auxiliary accumulators.

TABLE 3. INPUT SHIFT SELECTION

| SH1 | SH0 | SELECTED BITS |
| :---: | :---: | :---: |
| 0 | 0 | RINO-15, IMINO-15 |
| 0 | 1 | RIN1-16, IMIN1-16 |
| 1 | 0 | RIN2-17, IMIN2-17 |
| 1 | 1 | RIN3-18, IMIN3-18 |

The 33 bit real and imaginary outputs of the Complex Multiplier are latched in the Multiplier Registers and then go through the accumulator section of the CMAC. If the ACC line is high, the feedback to the accumulators is enabled; a low on ACC zeroes the feedback path, so that the next set of real and imaginary data out of the complex multiplier is stored in the CMAC Output Registers.

The data in the CMAC Output Registers goes to the Multiplexer, the output of which is determined by the OUTMUXO- 1 lines (Table 4). BINFMT\# controls whether the output of the Multiplexer is presented in two's complement or unsigned format; BINFMT\# $=0$ inverts ROUT19 and IOUT19 for unsigned output, while BINFMT\# $=1$ selects two's complement.

TABLE 4. OUTPUT MULTIPLEXER SELECTION

| OUT <br> MUX <br> 1 | OUT <br> MUX <br> 0 | RO16-19 | RO0-15 | 1016-19 | 100-15 |
| :---: | :---: | :--- | :--- | :--- | :--- |
| 0 | 0 | Real <br> CMAC <br> $31-34$ | Real CMAC <br> $15-30$ | Imag <br> CMAC <br> $31-34$ | Imag CMAO <br> $15-30$ |
| 0 | 1 | Real <br> CMAC <br> $31-34$ | 0, Real <br> CMAC <br> $0-14$ | Imag <br> CMAC <br> $31-34$ | 0, Imag <br> CMAC <br> $0-14$ |
| 1 | 0 | Real Acc <br> $16-19$ | Real Acc <br> $0-15$ | Imag Acc <br> $16-19$ | Imag Acc <br> $0-15$ |
| 1 | 1 | Reserved | Reserved | Reserved | Reserved |



FIGURE 3. COMPLEX MULTIPLIER/ACCUMULATOR; ALL REGISTERS CLOCKED BY CLK

The Complex Accumulator duplicates the accumulator in the CMAC. The input comes from the data shifters, and its 20 bit complex output goes to the Multiplexer. ACC controls whether the accumulator is enabled or not. OUTMUXO-1 determines whether the accumulator output appears on ROUT and IOUT.

The Growth Detect circuitry outputs a two bit value that signifies the amount of growth on the data in the CMAC and Complex Accumulator. Its output, DETO-1, is encoded as shown in Table 5. If PEAK\# is low, the highest value of DETO-1 is latched in the Growth Detect Output Register.

The relative weighting of the bits at the inputs and outputs of the CMAC is shown in figure 4. Note that the binary point of the sine, cosine, RIN and IIN is to the right of the most signif-
icant bit, while the binary point of RO and 10 is to the right of the fifth most significant bit. These CMAC external input and output busses are aligned with each other to facilitate cascading NCOM's for FFT applications.

TABLE 5. GROWTH ENCODING

| DET 1 | DET 0 | NUMBER OF BITS OF GROWTH ABOVE 2O |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 |

SIN/COS INPUT

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{0} 2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ |  |


| Radix Point |
| :--- |

COMPLEX MULTIPLIER/ACCUMULATOR INPUT (RIN, IIN)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

$2^{-20} .2^{-1} \quad 2^{-2} \quad 2^{-3} \quad 2^{-4} \quad 2^{-5} \quad 2^{-6} \quad 2^{-7} \quad 2^{-8} \quad 2^{-9} \quad 2^{-10} \quad 2^{-11} \quad 2^{-12} \quad 2^{-13} \quad 2^{-14} \quad 2^{-15}$ Radix Point

COMPLEX MULTIPLIER/ACCUMULATOR OUTPUT (RO, IO) OUTMUX = 00

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $-2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}, 2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ |
| Radix Point |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

COMPLEX MULTIPLIER/ACCUMULATOR OUTPUT (RO, IO)
OUTMUX = 01

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{-16}$ | $2^{-17}$ | $2^{-18}$ | $2^{-19}$ | $2^{-20}$ | $2^{-21}$ | $2^{-22}$ | $2^{-23}$ | $2^{-24}$ | $2^{-25}$ | $2^{-26}$ | $2^{-27}$ | $2^{-28}$ | $2^{-29}$ | $2^{-30}$ | 0 |

COMPLEX ACCUMULATOR OUTPUT (RO, IO)
OUTMUX $=10$

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0} .^{2-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ |  |
| Radix Point |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

FIGURE 4. BIT WEIGHTING

## HSP45116A Description and Operation

The operation of the HSP45116A is identical to the HSP45116 with the exception of a programmable rounding option added for the data outputs. The added functionality was acheived by using one of the HSP45116's reserved configuration registers to specify rounding precision and replacing a $V_{c c}$ pin with a round enable (RND\#) input. When RND\# is "high", rounding is disabled, and the HSP45116A functions as a pin-for-pin equivatent of the HSP45116. When RND\# is active "low" rounding is enabled. The RND\# input replaces $V_{\text {CC }}$ on PIN 75 of the 160 Lead MQFP package as seen in the pinout diagram.

The Round Control Register is loaded by placing the round control value on $\mathrm{C} 15-0$, setting $\mathrm{AD1-0}=11$, setting $\mathrm{CS} \#=0$, and forcing a low to high transition on the WR\# input. The
rounding operation is determined by the least significant 8 bits loaded into the control register as shown in Table 6. The least significant four bits (C3-0) loaded into the register govern rounding of the real and imaginary outputs of the Complex Accumulator (ACC). The next more significant four bits (C7-4) govern the rounding of the complex outputs of the complex multiply accumulator (CMAC). The real and imaginary outputs from the CMAC or ACC are rounded to the same precision. The rounding is perform by adding a "one" to the bit position below the least signifcant bit desired in the output. For example, for a configuration that rounds to the most signifcant 20 bits of the CMAC output, a "one" would be added to bit position $2^{-14}$ (See Figure 4 for output bit weightings).

TABLE 6. ROUNDING CONTROL

| ROUND CONTROL REGISTER |  |  | ROUNDING OPERATION |
| :---: | :---: | :---: | :---: |
| C15-8 | C7-4 | C3-0 |  |
| UNUSED | CMAC ROUNDING | ACC ROUNDING |  |
| XXXXXXXX | 0000 | 0000 | No Rounding |
|  | 0001 | 0001 | CMAC outputs rounded to most significant 20 bits, bit positions $-2^{4}$ to $2^{-15}$ ACC outputs rounded to most significant 20 bits, bit positions $-2^{4}$ to $2^{-15}$ |
| x $x$ xxxxxx | 0010 | 0010 | CMAC outputs rounded to most significant 19 bits, bit positions $-2^{4}$ to $2^{-14}$ ACC outputs rounded to most significant 19 bits, bit positions $-2^{4}$ to $2^{-14}$ |
| x $x$ x $x$ x $x$ x | 0011 | 0011 | CMAC outputs rounded to most significant 18 bits, bit positions $-2^{4}$ to $2^{-13}$ ACC outputs rounded to most significant 18 bits, bit positions $-2^{4}$ to $2^{-13}$ |
| xxxxxxxx | 0100 | 0100 | CMAC outputs rounded to most significant 17 bits, bit positions $-2^{4}$ to $2^{-12}$ ACC outputs rounded to most significant 17 bits, bit positions $-2^{4}$ to $2^{-12}$ |
| XXXXXXXX | 0101 | 0101 | CMAC outputs rounded to most significant 16 bits, bit positions $-2^{4}$ to $2^{-11}$ ACC outputs rounded to most significant 16 bits, bit positions $-2^{4}$ to $2^{-11}$ |
| xxxxxxxx | 0110 | 0110 | CMAC outputs rounded to most significant 15 bits, bit positions $-2^{4}$ to $2^{-10}$ ACC outputs rounded to most significant 15 bits, bit positions $-2^{4}$ to $2^{-10}$ |
|  | 0111 | 0111 | CMAC outputs rounded to most significant 14 bits, bit positions $-2^{4}$ to $2^{-9}$ ACC outputs rounded to most significant 14 bits, bit positions $-2^{4}$ to $2^{-9}$ |
| XXXXXXXX | 1000 | 1000 | CMAC outputs rounded to most significant 13 bits, bit positions $-2^{4}$ to $2^{-8}$ ACC outputs rounded to most significant 13 bits, bit positions $-2^{4}$ to $2^{-8}$ |
| XXXXXXXX | 1001 | 1001 | CMAC outputs rounded to most significant 12 bits, bit positions $-2^{4}$ to $2^{-7}$ ACC outputs rounded to most significant 12 bits, bit positions $-2^{4}$ to $2^{-7}$ |
| XXXXXXXX | 1010 | 1010 | CMAC outputs rounded to most significant 11 bits, bit positions $-2^{4}$ to $2^{-6}$ ACC outputs rounded to most significant 11 bits, bit positions $-2^{4}$ to $2^{-6}$ |
| XXXXXXXX | 1011 | 1011 | CMAC outputs rounded to most significant 10 bits, bit positions $-2^{4}$ to $2^{-5}$ ACC outputs rounded to most significant 10 bits, bit positions $-2^{4}$ to $2^{-6}$ |
|  | 1100 | 1100 | CMAC outputs rounded to most significant 9 bits, bit positions $-2^{4}$ to $2^{-4}$ ACC outputs rounded to most significant 9 bits, bit positions $-2^{4}$ to $2^{-4}$ |
|  | 1101-1111 | 1101-1111 | Undefined |

## Applications

The NCOM can be used for Amplitude, Phase and Frequency modulation, as well as in variations and combinations of these techniques, such as QAM. It is most effective in applications requiring multiplication of a rotating complex sinusoid by an external vector. These include AM and QAM modulators and digital receivers. The NCOM implements AM and QAM modulation on a single chip, and is a element in demodulation, where it performs complex down conversion. It can be combined with the Harris HSP43220 Decimating Digital Filter to form the front end of a digital receiver.

## Modulation/Demodulation

Figure 5 shows a block diagram of an AM modulator. In this example, the phase increment for the carrier frequency is loaded into the center frequency register, and the modulating input is clocked into the real input of the CMAC, with the imaginary input set to 0 . The modulated output is obtained at the real output of the CMAC. With a sixteen bit, two's complement signal input, the output will be a 16 bit real number, on ROUTO-15 (with OUTMUX $=00$ ).


FIGURE 5. AMPLITUDE MODULATION

By replacing the real input with a complex vector, a similar setup can generate QAM signals (Figure 6). In this case, the carrier frequency is loaded into the center frequency register as before, but the modulating vector now carries both amplitude and phase information. Since the input vector and the internally generated sine and cosine waves are both 16 bits, the number of states is only limited by the characteristics of the transmission medium and by the analog electronics in the transmitter and receiver.

The phase and amplitude resolution for the Sine/Cosine section ( 16 bit output), delivers a spectral purity of greater than 90 dBc . This means that the unwanted spectral components due to phase uncertainty (phase noise) will be greater than 90 dB below the desired output ( dBc , decibels below the carrier). With a 32 bit phase accumulator in the Phase/


FIGURE 6. QUADRATURE AMPLITUDE MODULATION (QAM)
Frequency Control Section, the frequency tuning resolution equals the clock frequency divided by 232 . For example, a 25 MHz clock gives a tuning resolution of 0.006 Hz .

The NCOM also works with the HSP43220 Decimating Digital Filter to implement down conversion and low pass filtering in a digital receiver (Figure 7). The NCOM performs complex down conversion on the wideband input signal by multiplying the input vector and the internally generated complex sinusoid. The resulting signal has components at twice the center frequency and at DC. Two HSP43220's, one each on the real and imaginary outputs of the HSP45116, perform low pass filtering and decimation on the down converted data, resulting in a complex baseband signal.


FIGURE 7. CHANNELIZED RECEIVER CHIP SET

## FFT Butterfly

Figure 8 shows a Fast Fourier Transform (FFT) implementation. The FFT is a highly efficient way of calculating the Discrete Fourier Transform [1]. The basic building block in FFTs is called the butterfly. The butterfly calculation involves adding complex numbers and multiplying by complex sinusoids. The Phase/Frequency Control Section and Sine/Cosine Generator provide the complex sinusoids and the CMAC performs the complex multiplies and adds.


FIGURE 8. RADIX-2 FFT BUTTERFLY
The NCOM circuit shown implements the butterfly shown in Figure 9. The two complex inputs $A$ and $B$ produce two complex outputs $A^{\prime}$ and $B^{\prime}$ using the equations $A^{\prime}=A+B$, $B^{\prime}=(A-B) W^{k}$ where $W^{k}=e^{-j w k}=\cos (w k)+j \sin (w k)$. Two clock cycles are required to calculate the butterfly. $A$ is clocked into the chip first and then $B$ is clocked in. The complex accumulator in the CMAC section adds A and B. The

CMAC calculates ( $A-B)^{k k}$ as $A W^{k}+B\left(-W^{k}\right)$. $-W^{k}$ is generated by phase shifting the ROM address 180 degrees using the phase modulation inputs. For radix-2 decimation in frequency FFTs, the phase of the complex sinusoid starts at 0 degrees and increments by a fixed step size (for each pass) after each butterfly. The phase/frequency section is initialized to 0 degrees and the frequency control loaded with the appropriate phase step size for the pass. The resulting words, $A^{\prime}$ and $B^{\prime}$, are held in output registers and multiplexed through the output pins for writing to memory. Using a single NCOM clocked at 25 MHz , a 1024 point radix-2 FFT can be computed in (CLK period) $x\left(\mathrm{Nlog}_{2} \mathrm{~N}\right)$, or 410 microseconds.


FIGURE 9. DECIMATION IN FREQUENCY BUTTERFLY

Circuitry is included to implement block floating point FFTs. In block floating point, an exponent is generated for an entire block of data. To implement block floating point, the maximum bit growth during a set of calculations is detected. The number of bits of growth is used to adjust the block's exponent and to scale the block on the next set of calculations to maintain a desired number of bits of precision. This technique requires less memory than true floating point and yields better performance than fixed point implementations, though its resolution does not meet that of true floating point implementations.

## References

[1] Oppenheim, A. V. and Schafer, R. W., Discrete Time Signal Processing, Prentice Hall

## Specifications HSP45116

| Absolute Maximum Ratings |  | Reliability Information |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | . . +8.0 V | Thermal Resistance | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| Input, Output or VO Voltage Applied. | .GND -0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ | MQFP Package | $22.0{ }^{\circ} \mathrm{CNW}$ | $7.7^{\circ} \mathrm{C} / \mathrm{N}$ |
| Storage Temperature Range . | . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | PGA Package | $23.1{ }^{\circ} \mathrm{CN}$ | 8.3CN |
| Junction Temperature |  | Maximum Package |  |  |
| MQFP | $+150^{\circ} \mathrm{C}$ | MQFP |  | . 3.6 W |
| PGA | . $+175{ }^{\circ} \mathrm{C}$ | PGA. |  | . 4.55 W |
| Lead Temperature (Soldering 10s). | . $+150^{\circ} \mathrm{C}$ | Component Count. . . . . . . . . . . . . . . . . . . . . . 103,000 Transistors |  |  |
| ESD Classification | . . Class 1 |  |  |  |

## Operating Conditions

Operating Voltage Range
+4.75 V to +5.25 V Operating Temperature Range
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNTTS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\mathrm{HHC}}$ | 3.0 | - | V | $\mathrm{V}_{C C}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | - | 0.8 | v | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{lOL}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 N}=\mathrm{V}_{C C}$ or GND, $\mathrm{V}_{C C}=5.25 \mathrm{~V}$ |
| I/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $I_{\text {ccsB }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $G N D \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Note 3 |
| Operating Power Supply Current | I'cop | - | 150 | mA | $f=15 \mathrm{MHz}, V_{\mathbb{I N}}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V},$ Notes 1 and 3 |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Note 2

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathbb{I N}}$ | - | 15 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, All measure- <br> ments are referenced to device ground |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 15 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for $I_{\text {ccop }}$ is 10 mAMHz .
2. Not tested, but characterized at initial design and at major process/design changes.
3. Output load per test load circuit with switch open and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | -15 (15MHz) |  | -25 (25.6MHz) |  | -33 (33MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| TCP | CLK Period | 66 |  | 39 |  | 30 |  | ns |  |
| ${ }^{T} \mathrm{CH}$ | CLK High | 26 |  | 15 |  | 12 |  | ns |  |
| ${ }^{\text {T }}$ CL | CLK Low | 26 |  | 15 |  | 12 |  | ns |  |
| TWL | WR\# Low | 26 |  | 15 |  | 12 |  | ns |  |
| TWH | WR\# High | 26 |  | 15 |  | 12 |  | ns |  |
| $\mathrm{T}_{\text {AWS }}$ | Set-up Time; ADO-1, CS\# to WR\# Going High | 18 |  | 13 |  | 13 |  | ns |  |
| TAWH | Hold Time; AD0, AD1, CS\# from WR\# Going High | 0 |  | 0 |  | 0 |  | ns |  |
| Tcws | Set-up Time C0-15 from WR\# Going High | 20 |  | 15 |  | 15 |  | ns |  |
| ${ }^{\text {T }}$ WWH | Hold Time C0-15 from WR\# Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TwC | Set-up time WR\# High to CLK High | 20 |  | 16 |  | 12 |  | ns | Note 3 |
| TMCS | Set-up Time MODO- 1 to CLK Going High | 20 |  | 15 |  | 15 |  | ns |  |
| ${ }^{\text {TMCH }}$ | Hold Time MODO-1 from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TPCS | Set-up Time PACI\# to CLK Going High | 25 |  | 15 |  | 11 |  | ns |  |
| TPCH | Hold Time PACI\# from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TECS | Set-up ENPHREG\#, ENCFREG\#, ENOFREG\#, ENPHAC\#, ENTIREG\#, CLROFR\#, PMSEL, LOAD\#,ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | 18 |  | 12 |  | 12 |  | ns |  |
| ${ }^{\text {TECH }}$ | Hold Time ENPHREG\#, ENCFREG\# ENOFREG\#,ENPHAC\#, ENTIREG\#, CLROFR\#, PMSEL, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TDS | Set-up Time RINO-18, IMINO-18 to CLK Going High | 18 |  | 12 |  | 12 |  | ns |  |
| ${ }^{\text {T }}$ DH | Hold Time RINO-18, IMINO-18 from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TDO | CLK to Output Delay RO0-19, 100-19 |  | 40 |  | 24 |  | 19 | ns |  |
| TDEO | CLK to Output Delay DETO-1 |  | 40 |  | 27 |  | 20 | ns |  |
| TPO | CLK to Output Delay PACO\# |  | 30 |  | 20 |  | 12 | ns |  |
| TTO | CLK to Output Delay TICO\# |  | 30 |  | 20 |  | 12 | ns |  |
| TOE | Output Enable Time OER\#, OEI\#, OEREXT\#, OEIEXT\# |  | 25 |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {MD }}$ | OUTMUXO-1 to Output Delay |  | 40 |  | 28 |  | 26 | ns |  |
| Ton | Output Disable Time |  | 20 |  | 15 |  | 15 | ns | Note 2 |
| $\mathrm{T}_{\text {RF }}$ | Output Rise, Fall Time |  | 8 |  | 8 |  | 6 | ns | Note 2 |

## notes:

1. A.C. testing is performed as follows: Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) OV and 3.0V; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with switch closed and $\mathrm{C}_{\mathrm{L}}=$ 40 pF . Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Applicable only when outputs are being monitered and ENCFREG\#, ENPHREG\#, or ENTIREG\# is active.

## Absolute Maximum Ratings

| Supply Voltage | +7.0V |
| :---: | :---: |
| Input, Output Voltage | GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | + $150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s) | $+300^{\circ} \mathrm{C}$ |
| ESD Classitication | Class 1 |

Reliability Information

| Thermal Resistance MQFP Package . . | $\begin{gathered} \theta_{\mathrm{JA}} \\ 22.0^{\circ} \mathrm{C} \mathrm{~W} \end{gathered}$ | $7.7^{\circ} \mathrm{CW}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at TBD |  |  |
| Gate Count |  | 00 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
Commercial. . . . . . . . . . . . . . . . . . . . . . . . . 4.75 V to +5.25 V Operating Temperature Range
Commercial. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

Electrical Specifications $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Current | $\mathrm{I}_{\text {ccop }}$ | - | TBD | mA | $\mathrm{V}_{\mathrm{cc}}=$ Max, CLK Frequency 52.6 Mhz Notes 1, 2 |
| Standby Power Supply Current | ICCsB | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Outputs Not Loaded |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{Cc}}=\mathrm{Max}$, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{Cc}}$ |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{H}}$ | 2.0 | - | V | $V_{C C}=$ Max |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical One Input Voltage: CLK | $\mathrm{V}_{\mathrm{IHC}}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |
| Logical One Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{l}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical Zero Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Input Capacitance | $\mathrm{ClN}_{\text {IN }}$ | - | 10 | pF | CLK Frequency 1 MHz |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 10 | pF |  |

NOTES:

1. Power supply current is proportional to frequency. Typical rating is $T B D \mathrm{~mA} / \mathrm{MHz}$. Note that operation at maximum clock frequency will exceed maximum junction temperature of device. Use of a heat sink and/or air flow is required under these conditions: recommended heat sink is TBD.
2. Output load per test circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Not tested, but characterized at initial design and at major process/design changes.

AC Electrical Specifications $\quad V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$ ), (Note 1)

| PARAMETER | SYMBOL | 52MHz ( -52 ) (PRELMINARY) |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| CLK Period | $T_{\text {cP }}$ | 19 | . | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 7 |  | ns |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 7 | ,.... | ns |
| WR\# Low | $T_{W}$ | 7 | ¢....... | ns |

Specifications HSP45116A Preliminary

AC Electrical Specifications $\quad V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$ ), (Note 1)


NOTES:

1. $A C$ tests performed with $C_{L}=40 \mathrm{pF}, \mathrm{I}_{\mathrm{OL}}=$ TBDmA, and $\mathrm{I}_{\mathrm{OH}}=-$ TBDmA. Input reference level for $C L K=2.0 \mathrm{~V}$, all other inputs 1.5 V . Test $\mathrm{V}_{\mathrm{H}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{HC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{OH}}=\mathrm{TBDV}, \mathrm{V}_{\mathrm{OL}}=\mathrm{TBDV}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
3. Applicable only when outputs are being monitored and ENCFREG\#, ENPHREG\# or ENTIREG\# is active.

Absolute Maximum Ratings<br>Supply Voltage<br>. . 88.0 V<br>Input or Output Voltage Applied .......... . GND -0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$<br>Storage Temperature Range $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$<br>Junction Temperature $+175^{\circ} \mathrm{C}$<br>Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . . . $300^{\circ} \mathrm{C}$<br>ESD Classification<br>$\qquad$ Class 1 of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.<br>\section*{Reliability Information}<br>Device Count.<br>103,000 Transistors<br>CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation

## Operating Conditions


DC Electrical Specifications $\quad \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | MIN: | MAx. | UNTTS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.2 | - | V | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | - | 08 | $v$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $V_{C C}=5.5 \mathrm{~V}$ |
| Logical Zero Input Voltage Clock | $\mathrm{V}_{\text {ILC }}$ | . | 08 | v | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | " | $v$ | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\text {cC }}=4.5 \mathrm{~V}$ (Note 1) |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | \% | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ (Note 1) |
| Input Leakage Current | 1 | -10 | $+10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |
| Output or I/O Leakage Current | 10 | -10. | +10. | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$ |
| Standby Power Supply Current | $\mathrm{I}_{\text {ccse }}$ | , | 500 | $\mu \mathrm{A}$ | $V_{I N}=V_{C C}$ or GND, $V_{C C}=5.5 \mathrm{~V}$, (Note 4) |
| Operating Power Supply Current | ICCOP |  | $150$ | mA | $\begin{aligned} & f=15 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Notes 2,4) } \end{aligned}$ |
| Functional Test | FT | \% | . ${ }^{\text {a }}$ |  | (Note 3) |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $10 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
4. Output per test load circuit with switch open and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

AC Electrical Specifications $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | -15 ( $15 \mathrm{MH} / 2$ ) |  | 25 (25.6MHz) |  | UNITS | (NOTE 1) CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Mis | Max | MIIN | NAX. |  |  |
| CLK Period | $T_{\text {cP }}$ | 66 | \% | 39 | * | ns |  |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 26. | \% | 15 | \% | ns |  |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 26 | , | 15 | T | ns |  |
| WR\# Low | $\mathrm{T}_{\text {WL }}$ | 26 | 4. | 15 | . | ns |  |
| WR\# High | $\mathrm{T}_{\text {WH }}$ | 26. | - | 15 | , | ns |  |
| Set-up Time; AD0-1, CS\# to WR\# Going High | $\mathrm{T}_{\text {AWS }}$ | 20 |  | ¢8 |  | ns |  |
| Hold Time; AD0, AD1, CS\# from WR\# Going High | $\mathrm{T}_{\text {AWH }}$ |  |  | $0$ |  | ns |  |
| Set-up Time C0-15 from WR\# Going High | T ${ }_{\text {cws }}$ | 20 | . | 18 | \#... | ns |  |

## AC Electrical Specifications $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Continued)

| PARAMETER | SYMBOL | , 5 ( $15 \mathrm{MH} / \mathrm{h}$ ) |  | 25 (256MH2) |  | UNITS | (NOTE 1) CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Mas | wsis | MiN\% | vas: |  |  |
| Hold Time C0-15 from WR\# Going High | $\mathrm{T}_{\text {cWH }}$ | 9 | ! | 0 | * | ns |  |
| Set-up Time WR\# to CLK High | $\mathrm{T}_{\text {wc }}$ | 20 | \% | 16 | . | ns | (Note 2) |
| Set-up Time MODO-1 to CLK Going High | $\mathrm{T}_{\text {MCS }}$ | 20 | \. | 18 | W...... | ns |  |
| Hold Time MOD0-1 from CLLK Going High | $\mathrm{T}_{\text {MCH }}$ | 0 | t | 0 | \% | ns |  |
| Set-up Time PACI\# to CLK Going High | TPCS | 25 | . | 18 | * | ns |  |
| Hold Time PACI\# from CLK Going High | $\mathrm{T}_{\mathrm{PCH}}$ | 0 | , | 0 | \%... | ns |  |
| Set-up Time ENPHREG\#, ENCFRCTL\#, ENPHAC\#, ENTICTL\#, CLROFR\#, PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | Tecs | $20$ |  | 15 |  | ns |  |
| Hold Time ENPHREG\#, ENCFRCTL\#, ENPHAC\#, ENTICTL\#, CLROFR\#, PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SH0-1, RBYTILD\# from CLK Going High | $\mathrm{T}_{\mathrm{ECH}}$ | 0 |  | $0$ |  | ns |  |
| Set-up Time RINO-18, IMINO-18 to CLK Going High | $\mathrm{T}_{\mathrm{DS}}$ | 20 |  | $15$ |  | ns |  |
| Hold Time RINO-18, IMINO-18, to CLK Going High | $\mathrm{T}_{\mathrm{DH}}$ | $0$ |  | $0$ |  | ns |  |
| CLK to Output Delay, RO0-19, 100-19 | $\mathrm{T}_{\mathrm{D}}$ |  | 40 | . | 25 | ns |  |
| CLK to Output Delay, DET0-1 | $\mathrm{T}_{\text {DEO }}$ | , | 40 |  | 27 | ns |  |
| CLK to Output Delay, PACO\# | $\mathrm{T}_{\mathrm{PO}}$ | - | 30 | - | 20 | ns |  |
| CLK to Output Delay, TICO\# | $\mathrm{T}_{\text {TO }}$ | . | 30 | - | 20 | ns |  |
| Output Enable Time, OER\#, OEI\#, OEREXT\#, OEIEXT\# | Toe |  |  |  | $20$ | ns | (Note 3) |
| OUTMUX0-1 to Output Delay | $\mathrm{T}_{\text {MD }}$ | - | 40 |  | 28 | ns |  |

NOTES:

1. AC testing is performed as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 3.0 V and 0 V ; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with switch closed and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Applicable only when outputs are being monitored and ENCFREG\#, ENPHREG\#, or ENTIREG\# is active.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage. Output loading per test load circuit, with switch closed and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

## Electrical Specifications

| PARAMETER | SYMBOL | NOTES | -15 |  | -25 |  | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MiN | Max |  |  |
| Output Disable Time | TOD | 1,2 | . | 20 | . | 15 | ns |  |
| Output Rise Time | $\mathrm{T}_{\text {R }}$ | 1,2 |  | 8 |  | 8 | ns | From 0.8V to 2.0 V |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | 1,2 | . | 8 |  | 8 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. The parameters in this table are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

## Waveforms



## Waveforms (Continued)



OUTPUT RISE AND FALL TIMES

Test Load Circuit


Switch $\mathbf{S} 1$ open for ${ }^{1} \mathrm{CCSB}$ and $\mathrm{I}_{\mathrm{CCOP}}$ tests
EQUIVALENT CIRCUIT

# Numerically Controlled Oscillator/Modulator 

## Features

- This Circult is Processed in Accordance to MIL-STD883 and Is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- NCO and CMAC on One Chip
- 15MHz and 25.6 MHz Versions
- 32-Bit Frequency Control
- 16-Bit Phase Modulation
- 16-Bit CMAC
- 0.006 Hz Tuning Resolution at $\mathbf{2 5 . 6 \mathrm { MHz }}$
- Spurious Frequency Components <-90dBc
- Fully Static CMOS


## Applications

- Frequency Synthesis
- Modulation - AM, FM, PSK, FSK, QAM
- Demodulation, PLL
- Phase Shifter
- Polar to Cartesian Conversions


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP45116GM-15/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 145 Lead PGA |
| HSP45116GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 145 Lead PGA |

## Description

The Harris HSP45116/883 combines a high performance quadrature numerically controlled oscillator (NCO) and a high speed 16-bit Complex Multiplier/Accumulator (CMAC) on a single IC. This combination of functions allows a complex vector to be multiplied by the internally generated (cos, $\mathbf{s i n}$ ) vector for quadrature modulation and demodulation. As shown in the block diagram, the HSP45116/883 is divided into three main sections. The Phase/Frequency Control Section (PFCS) and the Sine/Cosine Section together form a complex NCO. The CMAC multiplies the output of the Sine/ Cosine Section with an external complex vector.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The phase resolution of the PFCS is 32 -bits, which results in frequency resolution better than 0.006 Hz at 25.6 MHz . The output of the PFCS is the argument of the sine and cosine. The spurious free dynamic range of the complex sinusoid is greater than 90 dBc .

The output vector from the Sine/Cosine Section is one of the inputs to the Complex Multiplier/Accumulator. The CMAC multiplies this (cos, $\sin$ ) vector by an external complex vector and can accumulate the result. The resulting complex vectors are available through two 20-bit output ports which maintain the 90 dB spectral purity. This result can be accumulated internally to implement an accumulate and dump filter.

A quadrature down converter can be implemented by loading a center frequency into the Phase/Frequency Control Section. The signal to be downconverted is the Vector Input of the CMAC, which multiplies the data by the rotating vector from the Sine/Cosine Section. The resulting complex output is the down converted signal.

Block Diagram

 of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP45116/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{H}}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical Zero Input Voitage Clock | VILC | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T^{\prime} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | I'ccsb | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.5 V, \\ & \text { (Note 4) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & \mathrm{f}=15 \mathrm{MHz}, \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}(\text { Notes } 2,4) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 150 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $10 \mathrm{~mA} M \mathrm{Mz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
4. Output per test load circuit with switch open and $C_{L}=40 \mathrm{pF}$.

TABLE 2. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A sUBGROUPS | TEMPERATURE | -15 (15MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | ${ }^{\text {T }}$ CP |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| CLK High | ${ }^{\text {T }} \mathrm{CH}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| CLK Low | TCL |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| WR\# Low | TWL |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| WR\# High | TWH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| Set-up Time; AD0-1, CS\# to WR\# Going High | TAWS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time; ADO, AD1, CS\# from WR\# Going High | $\mathrm{T}_{\text {AWH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time C0-15 from WR\# Going High | Tcws |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time C0-15 from WR\# Going High | T ${ }^{\text {cwh }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time WR\# to CLK High | ${ }^{\text {Tw }}$ W | (Note 2) | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Set-up Time MODO-1 to CLK Going High | TMCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time MODO-1 from CLK Going High | $\mathrm{T}_{\mathrm{MCH}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time PACI\# to CLK Going High | TPCS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 18 | - | ns |
| Hold Time PACI\# from CLK Going High | $\mathrm{T}_{\mathrm{PCH}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time ENPHREG\# ENCFRCTL\#, ENPHAC\#, ENTICTL\# CLROFR\#, PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#,SHO-1, RBYTILD\# from CLK Going High | TECS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| Hold Time ENPHREG\#, ENCFRCTL\#, <br> ENPHAC\#, ENTICTL\# CLROFR\#, PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | TECH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time RINO-18, IMINO-18to CLK Going High | TDS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| Hold Time RINO-18, IMINO-18, to CLK Going High | $\mathrm{T}_{\mathrm{DH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |

## Specifications HSP45116/883

TABLE 2. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -15 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | Max | MIN | MAX |  |
| CLK to Output Delay ROO-19,100-19 | TDO |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 25 | ns |
| CLK to Output Delay DETO-1 | TDEO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 27 | ns |
| CLK to Output Delay PACO\# | TPO |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 20 | ns |
| CLK to Output Delay TICO\# | TтO |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 20 | ns |
| Output Enable Time OER\#, OEI\#, OEREXT\#, OEIEXT\# | ToE | (Note 3) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 20 | ns |
| OUTMUXO-1 to Output Delay | $\mathrm{T}_{\text {MD }}$ |  | 9, 10,11 | ${ }^{-55}{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 28 | ns |

## NOTES:

1. A.C. testing is performed as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) 3.0 V and OV ; Timing reference levels (CLK) 2.0V; All others 1.5V. Output load per test load circuit with switch closed and $C_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Applicable only when outputs are being monitored and ENCFREG\#, ENPHREG\#, or ENTIREG\# is active.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with switch closed and $C_{L}=40 \mathrm{pF}$.

TABLE 3. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -15 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ <br> Cout | $\mathrm{VCC}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$ All measurements are referenced to device GND. | 1 | $\mathrm{T}_{A}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance |  |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Time | TOD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

## NOTES:

1. The parameters in Table 3 are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Burn-In Circuit



Burn-In Circuit (Continued)

| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D3 | IMIN(0) | F4 | Q3 | ENPHAC\# | F1 | K14 | RO(2) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A10 | IO(18) | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| C2 | RIN(18) | F9 | P5 | ENTIREG\# | F4 | L15 | RO(3) | $\mathrm{v}_{\mathrm{CC} / 2}$ | B8 | IO(19) | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| D2 | RIN(17) | F8 | Q4 | ENI\# | F1 | J14 | RO(4) | $\mathrm{VCC} / 2$ | C8 | $\operatorname{IMIN}(18)$ | F9 |
| E3 | RIN(16) | F7 | N6 | MODPI/2PI\# | F16 | J13 | RO(5) | $\mathrm{v}_{\mathrm{CC} / 2}$ | C7 | $\operatorname{IMIN}(17)$ | F8 |
| C1 | RIN(15) | F6 | P6 | CS\# | F2 | K15 | RO(6) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A7 | $\operatorname{IMIN}(16)$ | F7 |
| E2 | RIN(14) | F5 | Q5 | CLK | FO | H14 | RO(7) | $\mathrm{v}_{\mathrm{cc} / 2}$ | A6 | IMIN(15) | F6 |
| D1 | RIN(13) | F4 | P7 | AD(1) | F4 | H13 | RO(8) | $\mathrm{v}_{\mathrm{cc} / 2}$ | B7 | $\operatorname{IMIN}(14)$ | F5 |
| F3 | RIN(12) | F16 | N7 | $\mathrm{AD}(0)$ | F3 | G13 | RO(9) | $\mathrm{V}_{\mathrm{CC}} / 2$ | B6 | IMIN(13) | F4 |
| F2 | RIN(11) | F15 | Q6 | WR\# | F1 | G15 | RO(10) | $\mathrm{V}_{\mathrm{cc}} / 2$ | C6 | $\operatorname{IMIN}(12$ | F16 |
| E1 | RIN(10) | F14 | P8 | C(15) | GND | F15 | RO(11) | $\mathrm{v}_{\mathrm{CC} / 2}$ | A5 | IMIN(11) | F15 |
| G2 | RIN(9) | F13 | N8 | C(14) | GND | G14 | RO(12) | $\mathrm{v}_{\mathrm{cc} / 2}$ | B5 | $\operatorname{IMIN}(10)$ | F14 |
| G3 | RIN(8) | F12 | N9 | C(13) | GND | F14 | RO(13) | $\mathrm{V}_{\mathrm{cc} / 2}$ | A4 | $\operatorname{IMIN}(9)$ | F13 |
| F1 | RIN(7) | F11 | Q9 | C(12) | GND | F13 | RO(14) | $\mathrm{v}_{\mathrm{cc} / 2}$ | A3 | $\operatorname{IMIN}(8)$ | F12 |
| H2 | RIN(6) | F10 | Q10 | C(11) | GND | E15 | RO(15) | $\mathrm{v}_{\mathrm{CC} / 2}$ | B4 | $\operatorname{IMIN}(7)$ | F11 |
| H3 | RIN(5) | F9 | P9 | C(10) | GND | E14 | RO(16) | $\mathrm{v}_{\mathrm{CC} / 2}$ | C5 | $\operatorname{IMIN}(6)$ | F10 |
| J3 | RIN(4) | F8 | P10 | C(9) | GND | D15 | RO(17) | $\mathrm{v}_{\mathrm{cc}} / 2$ | B3 | $\operatorname{IMIN}(5)$ | F9 |
| J1 | RIN(3) | F7 | N10 | C(8) | GND | C15 | RO(18) | $\mathrm{V}_{\mathrm{cc} / 2}$ | A2 | $\operatorname{IMIN}(4)$ | F8 |
| K1 | RIN(2) | F6 | Q11 | C(7) | GND | D14 | RO(19) | $\mathrm{V}_{\mathrm{cc}} / 2$ | C4 | $\operatorname{IMIN}(3)$ | F7 |
| J2 | RIN(1) | F5 | P11 | C(6) | GND | E13 | 10(0) | $\mathrm{V}_{\mathrm{CC} / 2}$ | C3 | $\operatorname{IMIN}(2)$ | F6 |
| K2 | RIN(0) | F4 | Q12 | C(5) | GND | C14 | 10(1) | $\mathrm{VCC} / 2$ | B2 | $\operatorname{IMIN}(1)$ | F5 |
| K3 | SH(1) | F3 | Q13 | C(4) | GND | B15 | 10(2) | $\mathrm{v}_{\mathrm{cc} / 2}$ | A1 | $\mathrm{V}_{\mathrm{Cc}}$ | None |
| L. 1 | SH(0) | F2 | P12 | C(3) | GND | D13 | 10(3) | $\mathrm{VCC}^{\prime} 2$ | A9 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| L2 | ACC | F4 | N11 | C(2) | GND | C13 | 10(4) | $\mathrm{V}_{\mathrm{CC} / 2}$ | A15 | $\mathrm{V}_{\mathrm{CC}}$ | None |
| M1 | ENPHREG\# | F16 | P13 | C(1) | GND | B14 | 10(5) | $\mathrm{V}_{\mathrm{cc}} / 2$ | G1 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| N1 | ENOFREG\# | F4 | Q14 | C(0) | $\mathrm{V}_{\mathrm{CC}}$ | C12 | 10(6) | $\mathrm{V}_{\mathrm{CC}} / 2$ | 115 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| M2 | PEAK\# | F8 | N12 | OUTMUX(1) | F11 | B13 | $10(7)$ | $\mathrm{v}_{\mathrm{CC}} / 2$ | Q1 | $V_{\text {CC }}$ | None |
| L3 | RBYTILD\# | F16 | N13 | OUTMUX(0) | F10 | B12 | $10(8)$ | $\mathrm{V}_{\mathrm{CC}} / 2$ | Q7 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ |
| N2 | BINFMT\# | F4 | P14 | OER\# | FO | C11 | 10(9) | $\mathrm{V}_{\mathrm{CC}} / 2$ | Q15 | $\mathrm{V}_{\mathrm{CC}}$ | None |
| P1 | TICO\# | $\mathrm{V}_{\mathrm{CC} / 2}$ | M13 | OEREXT\# | Fo | A13 | 10(10) | $\mathrm{V}_{\mathrm{cc}} / 2$ | A8 | GND | GND |
| M3 | MOD(1) | GND | N14 | OEIEXT\# | FO | B11 | 10(11) | $V_{C C / 2}$ | A14 | GND | None |
| N3 | MOD(0) | GND | M14 | OEI\# | Fo | A12 | 10(12) | $V_{C C / 2}$ | B1 | GND | None |
| P2 | PACI\# | F4 | L13 | PACO\# | $\mathrm{v}_{\mathrm{CC} / 2}$ | C10 | 10(13) | $V_{C C} / 2$ | H1 | GND | GND |
| N4 | LOAD\# | F15 | N15 | DETO | $\mathrm{v}_{\mathrm{CC} / 2}$ | B10 | 10(14) | $\mathrm{V}_{C C / 2}$ | H15 | GND | GND |
| P3 | PMSEL | F1 | L14 | DET1 | $\mathrm{V}_{\mathrm{cc} / 2}$ | A11 | 10(15) | $\mathrm{V}_{\mathrm{CC}} / 2$ | P15 | GND | None |
| P4 | CLROFR\# | F4 | M15 | RO(0) | $\mathrm{v}_{\mathrm{cc}} / 2$ | B9 | 10(16) | $V_{\mathrm{CC}} / 2$ | Q2 | GND | None |
| N5 | ENCFREG\# | F4 | K13 | RO(1) | $\mathrm{v}_{\mathrm{cc} / 2}$ | C9 | 10(17) | $\mathrm{V}_{\mathrm{CC} / 2}$ | Q8 | GND | GND |

## NOTES:

1. $\mathbf{4 7 K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND

[^5]3. $F 0=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, \ldots, F 11=F 10 / 2,40 \%$ to 60\% duty cycle
4. Input Voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \max , \mathrm{~V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

Die Characteristics
DIE DIMENSIONS: WORST CASE CURRENT DENSITY: $1.6 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
$350 \times 353 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

Metallization Mask Layout
HSP45116/883


# DOWN CONVERSION AND DEMODULATION 

PAGE
DOWN CONVERSION AND DEMODULATION DATA SHEETS
HSP50016 Digital Down Converter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-3
HSP50110
Digital Quadrature Tuner
6-25

NOTE: Bold Type Designates a New Product from Harris.
-

Digital Down Converter

## Features

- 52 MSPS Input Data Rate
- 16-Bit Data Input
- Spurious Free Dynamic Range Through Modulator $>102 \mathrm{~dB}$
- Frequency Selectivity: $<\mathbf{0 . 0 0 6 H z}$
- Identical Lowpass Filters for I and Q
- Passband Ripple: <0.04dB
- Stopband Attenuation: >104dB
- Filter -3dB to -102dB Shape Factor: <1.5
- Decimation from 64 to 131,072
- IEEE 1149.1 Test Access Port


## Applications

- Digital Radio Receivers
- Channelized Receivers
- Spectrum Analysis


## Ordering Information

| PART <br> NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :--- |
| HSP50016JC-52 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 44 Lead PLCC |
| HSP50016GC-52 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 48 Lead PGA |

## Description

The Digital Down Converter (DDC) is a single chip synthesizer, quadrature mixer and lowpass filter. Its input data is a sampled data stream of up to 16 -bits in width and up to a 52 MSPS data rate. The DDC performs down conversion, narrowband low pass filtering and decimation to produce a baseband signal.

The internal synthesizer can produce a variety of signal formats. They are: CW, frequency hopped, linear FM up chirp, and linear FM down chirp. The complex result of the modulation process is lowpass filtered and decimated with identical real filters in the in phase (I) and quadrature (Q) processing chains.

Lowpass filtering is accomplished via a high decimation filter (HDF) followed by a fixed finite impulse response (FIR) filter. The combined response of the two stage filter results in a -3 dB to -102dB shape factor of better than 1.5. The stopband attenuation is greater than 106 dB . The composite passband ripple is less than 0.04 dB . The synthesizer and mixer can be bypassed so that the chip operates as a single narrow band low pass filter.

The chip receives forty bit serial commands as a control input. This interface is compatible with the serial I/O port available on most microprocessors.

The output data can be configured in fixed point or single precision floating point. The fixed point formats are 16, 24, 32 , or 38 bit, two's complement, signed magnitude, or offset binary.

The circuit provides an IEEE 1149.1 Test Access Port.

Block Diagram


## Pinouts



HSP50016

## Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | 7, 12, 18, 23, 28, 40 | - | +5V Power |
| GND | 6, 13, 19, 27, 34, 39 | - | Ground |
| DATAO-15 | 8-11, 15-17, 29-33, 35-38 | 1 | input data bus. Selectable between two's complement and offset binary. DATAO is the LSB. |
| CLK | 14 | 1 | Clock for input data bus. |
| RESET\# | 26 | 1 | RESET\# initializes the internal state of the DDC. During RESET\#, all internal processing stops. RESET\# facilitates the synchronization of multiple chips for Auto Three-State operation. If the Force bits in control word 7 are inactive and the IEEE Test Access Port is in an Idie state, RESET\# causes the IQCLK, IQSTB, I and Q outputs to go to a high impedance state. <br> All control registers are updated from their respective control buffer registers on the third rising edge of CLK after the deassertion of RESET\#. If RESET\# is deasserted $\mathrm{T}_{\text {RR }}$ nanoseconds prior to the rising edge of CLK, the internal reset will deassert synchronously. If $T_{R R}$ is violated, then the circuit contains a synchronizer which will cause reset to be deasserted internally one or more clocks later. <br> An initial reset is required to guarantee proper operation of the DDC. Active low. |
| 1 | 4 | 0 | The I output has three modes: I data; I data followed by $Q$ data; real data. |
| Q | 5 | 0 | The Q output has two modes: Q data and the carry out of the Phase Adder. |
| IQCLK | 3 | 0 | IQCLK: bit or word clock for the I and Q outputs. |
| IQSTB | 1 | 0 | IQSTB: beginning or end of word indicator for 1 and $Q$. |
| IQSTRT\# | 2 | 1 | Initiates output data sequence. Active low. |
| CDATA | 44 | 1 | Port for control data input. |
| CCLK | 41 | 1 | Control data input bit clock. |
| CSTB | 42 | 1 | Beginning of word indicator for control data. |
| CS\# | 43 | 1 | Enables control data loading of DDC. Active low. |
| TCK | 25 | 1 | Bit clock for IEEE 1149.1 data. |
| TMS | 24 | 1 | Test port mode select. |
| TDI | 20 | 1 | Input data IEEE test port. |
| TDO | 22 | 0 | Output data for IEEE test port. |
| TRST\# | 21 | 1 | Test port reset. Active low. |



## Phase Generator Block Diagram



FIGURE 2

## Functional Description

The primary function of the DDC is to extract a narrow band of interest from a wideband input, convert that band to baseband and output it in either a quadrature or real form. This is accomplished by centering the band of interest at DC by multiplying the input data times a quadrature sinusoid. A quadrature lowpass filter (identical real lowpass filters in the in phase ( $I$ ) and quadrature phase ( $Q$ ) processing branches) is applied to the result. Each filtering chain consists of a cascaded HDF and FIR filter, which extract the band of interest. During filtering, the signal is decimated by a rate which is proportional to the output bandwidth. The bandwidth of the resulting signal is the double sided passband width of the lowpass filters. An Output Formatter manipulates the filter output to provide the data in a variety of formats.

## Local Oscillator

Signal data clocked into the DATAO-15 input of the DDC is multiplied by a quadrature sinusoid in the Mixer section. (See Figure 1). The data input to the DDC is a 16 bit real data stream which is sampled on the rising edges of CLK. It can be in two's complement or offset binary format.

The input data is passed to a mixer, which is composed of two real multipliers. One of these multiplies the input data samples by the in phase (cosine) component of the quadrature sinusoid and the other multiplies the input data samples by the quadrature (sine) component. The in phase and quadrature data paths are designated $\mathbf{I}$ and $\mathbf{Q}$ respectively. The sine and cosine are generated in the local oscillator as shown in Figure 1.

The local oscillator is programmed to produce a quadrature sinusoid with programmable frequency and phase. The frequency can be constant (Continuous Wave - CW), linearly increasing (up chirp), linearly decreasing (down chirp), or linear up/down chirp. The initial phase of the waveform is set by the phase offset.
The phase, frequency and chirp limits of the quadrature sinusoid are controlled by the Phase Generator (Figure 2). The output of the Phase Generator is an 18 bit phase word that represents the current phase angle of the complex sinusoid. The Phase Generator automatically increments the phase angle by a preprogrammed amount on every rising edge of CLK. Stepping the output phase from 0 through full scale ( $2^{18}-1$ ) steps the phase angle of the quadrature sinusoid from 0 to $\left(-2+2^{-17}\right) \pi$ radians. The frequency of the complex sinusoid is determined by the number of clocks needed for the phase to step though its full range of $2 \pi$ radians. The required phase increment for a given local oscillator frequency is calculated by:

Finase increment $=2^{20} t_{d} / t_{S}$
where:
$f_{C}$ is the desired local oscillator frequency
$f_{S}$ is the input sampling frequency
There are five parameters which control the Phase Generator. They are: phase offset, minimum phase incre-
ment, maximum phase increment, delta phase increment and mode control. Mode control is used to select the function of the other parameters.
The phase offset is the initial setting of the phase word going to the SIN/COS Generator. Subsequent phases of the sinusoid are calculated relative to this offset. The minimum phase increment has two mode dependent functions: when the SIN/COS Generator is forming a CW waveform, the minimum phase increment is the phase step taken on every clock. When the SIN/COS Generator is producing a chirped sinusoid, the minimum phase increment is the smallest phase step taken. Maximum phase increment is only used during chirped modes; it is the largest allowable phase increment. During chirp modes, the delta phase increment is the difference between successive phase increments.

The four phase parameters are stored in their respective registers in the Phase Generator. The Phase Register stores the current phase angle. On the first clock following the deassertion of RESET\#, the 18 MSBs of the Phase Register are loaded from the Phase Offset Register. On every rising edge of CLK thereafter, the output of the Phase Increment Register is subtracted from the 32 LSBs of the current phase. The 33 bit difference is stored back in the Phase Register on the next CLK. The 18 most significant bits of the Phase Register form the phase word, which is the input to the SIN/COS Generator.

Figure 3 gives a graphic representation of the four phase parameters. To understand their interrelationships, the phase should be visualized as the angle of a rotating vector. When the local oscillator in the DDC is programmed to generate a CW waveform, the multiplexers are configured so that the Minimum Phase increment is stored in the Phase Increment Register; this value is subtracted from the output of the Phase Register on every CLK and the difference becomes the new Phase Register value. The Delta Phase Increment and Maximum Phase Increment are ignored.


FIGURE 3. PHASE WORD PARAMETERS FOR CW CASE
In up chirp mode the local oscillator generates a signal with a linearly increasing frequency (Figure 4A). The Phase Increment Register is initially loaded with the Minimum Phase Increment value; on every clock, the contents of the

Phase Increment Register is subtracted from the current output of the Phase Register. Simultaneously, the Delta Phase Increment Register is added to the 24 LSBs of the output of the Phase Increment Register. On the next CLK, that sum is stored back in the Phase Increment Register, the new phase is stored in the Phase Register and the process is repeated. The phase increment is allowed to grow until the next phase increment would exceed the maximum phase increment value. When this happens, the Phase Increment Register is reset to the minimum phase increment and the cycle starts over again. Note that the phase increment is never equal to the maximum phase increment. From the time the Phase Generator starts at the minimum phase increment until it reaches the maximum phase increment, the phase word on clock n is given by:
Phase Word = Phase Offset - [Minimum Phase Increment $+n$ (Delta Phase Increment)]

An example of the outputs of the Phase Increment Register, Phase Register, and the I output of the SIN/COS Generator are shown in Figure 4B.


FIGURE 4A. PHASE WORD DURING UP CHIRP.


cosine output of sincoos generator


FIGURE 4B. UP CHIRP

In down chirp mode the local oscillator generates a signal with a linearly decreasing frequency (Figure 5A). The maximum phase increment is loaded into the Phase Increment Register and the phase offset value goes into the Phase Register. The delta phase increment is subtracted from the 24 LSBs of the phase increment to form a new phase increment at each clock. The phase increment is allowed to diminish until it reaches the minimum phase increment value, then it is reset to the maximum phase increment value and the cycle is repeated. Note that the value of the phase increment can be equal to, but never less than the minimum phase increment, since the Phase Increment Register is reloaded if the next phase increment value would be less than the minimum phase increment. This feature protects the DDC from exceeding the Nyquist frequency. In this case, from the time the Phase Generator starts at the maximum phase increment until it reaches the minimum phase increment, the phase word on clock $n$ is given by:
Phase Word = Phase Offiset - [Maximum Phase Increment
-n (Delta Phase Increment) $]$
See Figure 5B for a graphical representation of this process.


FIGURE 5A. PHASE WORD DURING DOWN CHIRP

PHASE INCREMENT


cosine output of sincos generator


FIGURE 5B. DOWN CHIRP

In up/down chirp mode, the phase accumulator is set to the phase offset value and the minimum phase increment is loaded into the Phase Increment Register. The delta phase increment is added to the 24 LSBs of the Phase Increment Register to form a new phase increment at each clock. The phase increment is allowed to grow until it nears the maxmum phase increment value (as defined in the up chirp description). The delta phase increment value is then subtracted from the least significant bits of the Phase Increment Register to form a new phase increment at each clock. The phase increment is allowed to diminish until it reaches the minimum phase increment value (as defined in the down chirp description). The Phase Increment Register is then reloaded with the minimum phase increment, and the up/ down cycle begins again. See Figure 6 for a graphical representation of this process.

The minimum and maximum phase increments have allowable values from 0 to $2^{32}-1$. This corresponds to the phase increment:

$$
0<\text { Phase Increment }<\pi\left(1-2^{-32}\right) \text { radians }
$$

The Delta Phase Increment parameter can take on values from 0 to $2^{24}-1$ which corresponds to the Delta Phase Increment:

$$
0<\text { Delta Phase Increment }<\pi\left(2^{-8}-2^{-32}\right) \text { radians }
$$

The output of the phase accumulator forms the input to the SIN/COS Generator which in turn produces a quadrature vector which rotates clockwise: the outputs are $\cos (\omega n)$ and $-\sin (\omega n)$. The outputs of the SIN/COS Generator are two's complement values which are scaled to prevent overflow in subsequent operations in the DDC under normal operation. The scale factor has a negligible effect on the end to end DDC gain.

## PHASE INCREMENT




COSINE OUTPUT OF SIN/COS GENERATOR


FIGURE 6. UP/DOWN CHIRP

The frequency resolution of the DDC = (frequency of CLK) / (Number of Phase Register bits). At the maximum clock rate, this results in a frequency selectivity of $52 \mathrm{MHz} / 2^{33}=$ 0.006 Hz . The 18 bit phase word yields a phase noise Figure of greater than 102dB.

## Mixer

The Mixer performs quadrature modulation by multiplying the output of the SIN/COS Generator by the input data. The outputs of the I and Q multipliers are symmetrically rounded to 17 bits to preserve the 102 dB spurious free dynamic range (SFDR). The result of the quadrature modulation process is passed to the High Decimating Filter (HDF) section.

## High Decimation Filter

The High Decimation Filter (HDF) section is comprised of two real HDF filters, one processing the I data branch and one processing the Q data branch. Each branch has the lowpass response shown in Figure 7. The undecimated frequency impulse response is given by the equation:

$$
H(f)=(\operatorname{Sin}(\pi f) / \operatorname{Sin}(\pi f / R))^{5}
$$

In Figure 7, $f^{\prime}=f_{S} / R$, the input sample rate divided by the HDF decimation factor. Figure 7 shows this curve from DC to the first null. Note that the HDF is a true FIR filter; i.e., the phase is linear.

The data path through the HDF was designed to ensure a true 16 bit noise floor (approximately 98 dB ) at the output of the DDC. The structure of the HDF filter used in the DDC is a five stage decimation filter. The width of each successive stage decreases such that the LSBs are lost due to truncation [1]. As a result, the data must be processed in the MSBs of the filter so that the noise due to truncation is below the required noise floor. This means that the input data of the HDF must be shifted so that its output data fills the HDF output word. The shift is a function of the desired HDF decimation rate $R$ and the number of stages, which is fixed at 5. The shift is performed by the Data Shifter, which positions the input data to the HDF for the maximum dynamic range while avoiding overflow errors. The shift factor is programmed into the Shift field of Control Word 4. The value in this field is calculated by the equation:

Shift = 75 - Ceiling $\left(5 \log _{2}(R)\right.$ )


FIGURE 7. FREQUENCY RESPONSE OF HIGH DECIMATION FILTER FROM DC TO FIRST NULL
where $R$ is the HDF decimation rate and Ceiling $(X)$ denotes the ceiling function of $X$; i.e., the result is $X$ if $X$ is an integer, otherwise the result is the next higher integer.
The output data rate of the HDF is CLK divided by the HDF decimation rate (programmed into the HDF Decimation field in Control Word 5).
During RESET\#, the HDF is initialized and will not output any information until it is filled with new data.

## Scaling Multipliers

The output of each HDF is passed to a Scaling Multiplier. The Scaling Multipliers are used to compensate for the HDF gain, which is between 1 (inclusive) and 0.5 (noninclusive), or $(0.5,1.0]$. The gain through the HDF is dependent on the decimation factor: when the decimation is a power of two, the HDF gain is equal to 1 ; otherwise, the gain must be compensated for in the Scaling Multiplier. The HDF gain is given by the equation:

$$
\begin{equation*}
\text { HDF Gain } \left.=R^{5} / 2^{\text {Ceiling(5log }} 2(\mathrm{R})\right) \tag{3}
\end{equation*}
$$

where $R$ is the HDF decimation rate. The compensating Scale Factor, which is input to both Scaling Multipliers, is given by the equation:


FIGURE 8. FREQUENCY RESPONSE OF FIR FILTER

Note that the Scale Factor falls in the interval [1,2). The output of the scaling multiplier is symmetrically rounded to 17 bits.

The binary formats of the inputs and outputs of the scaling multiplier are as follows:

$$
\begin{array}{ll}
\text { Input from HDF: } & a_{0}\left(-2^{0}\right) \cdot a_{1}\left(2^{-1}\right) a_{2}\left(2^{-2}\right) \ldots a_{17}\left(2^{-17}\right) \\
\text { Scale factor: } & a_{0}\left(2^{0}\right) \cdot a_{1}\left(2^{-1}\right) a_{2}\left(2^{-2}\right) \ldots a_{15}\left(2^{-15}\right) \\
\text { Output: } & a_{0}\left(-2^{0}\right) \cdot a_{1}\left(2^{-1}\right) a_{2}\left(2^{-2}\right) \ldots a_{16}\left(2^{-16}\right)
\end{array}
$$

## FIR Filter

The Scaling Multiplier output is passed to the FIR Filter, which performs aliasing attenuation, passband roll off compensation and transition band shaping. The FIR Filter Section is functionally two identical 121 tap lowpass FIR filters, one each for the I and Q channel. The two filters are each implemented as sum of products, each with a single multiplier, with the coefficients stored in ROM. The filters' passbands are precompensated to be the inverse of the response of the HDF. The frequency response of the FIR filters is shown in Figure 8. The composite HDF and FIR filter frequency response is shown in Figure 9. The FIR coefficients are scaled so that the maximum gain of the composite filter is less than or equal to 0 dB . The composite passband ripple is less than 0.04 dB .


FIGURE 9. END TO END FREQUENCY RESPONSE OF DDC

The coefficients of the filter are quantized to 22 bits to preserve greater than 106 dB of stopband attenuation. The sum of products of each filter output calculation is a 38 bit number with 37 fractional bits.

When a quadrature output is selected, the outputs of the FIR filters are decimated by a factor of four. When real output is selected, only the I output is active. The output is decimated by two in this case. When Filter Only mode is selected, only the I filter path is active and its output is decimated by four.
The composite filter bandwidths are a function of the HDF decimation rate and the FIR Filter shape. The double sided bandwidths are specified by the following equations.

$$
\begin{align*}
& -3 \mathrm{~dB} \text { BW }=0.13957 \times f^{\prime}  \tag{5}\\
& -102 \mathrm{~dB} B W=0.19903 \times \mathrm{f}^{\prime} \tag{6}
\end{align*}
$$

## Output Control

The circuit has two serial data outputs, I and Q. The timing of the output bits is referenced to IQCLK and IQSTB. There are several modes of operation for the data and control lines, all of which were designed to be compatible with common microprocessors. These modes are programmed by loading the appropriate control words (see Table 1 through Table 8).
The I output has three modes: I data out; I data followed by $Q$ data; and real data out. The $Q$ pin can output either $Q$ data or the carry out of the Phase Adder. Both outputs can be programmed to set the number of significant bits transmitted; the arithmetic representation; the order of the bits, LSB or MSB first; and the polarity of the data bits, high or low true. The spectral sense of the output data is selectable between normal and reversed. The spectral orientation of the data is selectable between baseband centered quadrature, baseband offset quadrature, and baseband real. In addition, the output drivers for I, Q, IQCLK and IQSTB can be individually enabled or placed in a high impedance state using Control Word 6. These options are explained below.
Quadrature data output can occur in one of two ways: simultaneously or sequentially. The simultaneous method clocks out the I and $Q$ data on their respective output pins. The I followed by Q method clocks I and Q out sequentially on the I output pin: the entire I word is serially clocked out first, then the entire $\mathbf{Q}$ word. In real data output mode, the Formatter converts the quadrature data to real and clocks it out serially on the I output pin. In all modes, the I and Q outputs return to the zero state after the last bit is transmitted.

TABLE 1. FORMAT FOR CONTROL WORD (0) - CONTROL REGISTER UPDATE

| DIT <br> POSTIION | FUNCTION | DESCRIPTION |
| :--- | :--- | :--- |
| $39-37$ | Address | $000=$ Control Word 0 |
| 36 | Update | $0=$ No Control Register Update <br> Update |
| $35-32$ | Reserved | All zeroes |

TABLE 2. FORMAT FOR CONTROL WORD 1 - PHASE GENERATOR / TEST ENABLE / OUTPUT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 001 = Control Word 1 |
| 36 | Update | $0=$ No Control Register Update <br> 1 = Control Register Update |
| 35-4 | Minimum Phase Increment | Bits 35-4 = $2^{31} \ldots 2^{0}$ |
| 3 | Test Enable | $\begin{aligned} & 0=\text { Test Features Disabled } \\ & 1=\text { Test Features Enabled } \end{aligned}$ |
| 2-0 | Phase <br> Generator Mode | $\begin{aligned} & 000 \text { = Filter Only } \\ & 001 \text { = Normal Mode (CW) } \\ & 010=\text { Reserved } \\ & 011 \text { = Up Chirp } \\ & 100 \text { = Reserved } \\ & 101 \text { = Down Chirp } \\ & 110 \text { = Reserved } \\ & 111 \text { = Up/Down Chirp } \end{aligned}$ |

TABLE 3. FORMAT FOR CONTROL WORD 2 - PHASE GENERATOR

| BIT <br> POSITION | FUNCTION | DESCRIPTION |
| :--- | :--- | :--- |
| $39-37$ | Address | $010=$ Control Word 2 |
| 36 | Update | $0=$ No Control Register Update <br> $1=$ Control Register Update |
| $35-32$ | Reserved | All zeroes |
| $31-0$ | Maximum <br> Phase <br> Increment | Bits $31-0=2^{31} \ldots 2^{\circ}$. |

TABLE 4. FORMAT FOR CONTROL WORD 3 - PHASE GENERATOR / OUTPUT TIME SLOT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 011 = Control Word 3 |
| 36 | Update | $0=$ No Control Register Update 1 = Control Register Update |
| 35-32 | Reserved | All zeroes |
| 31-19 | Time Slot Length | Time Slet length in: 0 OLK pori: ods; length = number of bits + 2. Bits 31-18 $=2^{13} \ldots 2^{0}$. |
| 17-0 | Phase Ofiset | Starting phase angle of phase accumulator; range $=0$ to $2 \pi$. Bits $17-0=2^{33} \ldots 2^{16}$ |

HSP50016

TABLE 5. FORMAT FOR CONTROL WORD 4 - PHASE GENERATOR / HDF I OUTPUT

| BIT POSITION | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 100 = Control Word 4 |
| 36 | Update | $0=$ No Control Register Update <br> 1 = Control Register Update |
| 35-33 | Reserved | All zeroes |
| 32-31 | Output Spectrum | $\begin{aligned} & 00=\text { No Up Conversion, Com- } \\ & \text { plex Output } \\ & 01=\text { Up Convert by f"/4, Real } \\ & \text { Output } \\ & 10=\text { Up Convert by f"/2, Com- } \\ & \text { plex Output } \\ & 11=\text { Reserved Mode } \end{aligned}$ |
| 30-7 | Delta Phase Increment | 24 Bit Delta Phase Increment. Bits $30-7=2^{23} \ldots 2^{0}$. |
| 6-1 | HDF Data Shift | HDF input data shift (towards LSB). Bits $6-1=2^{5} \ldots 2^{0}$. <br> Shift $=75$ - Ceiling( $5 \log _{2}(\mathrm{R})$ ) |
| 0 | Spectral Reverse | $\begin{aligned} & 0=\text { Normal output } \\ & 1=\text { Spectrally Reversed output } \end{aligned}$ |

TABLE 6. FORMAT FOR CONTROL WORD 5 - HDF / OUTPUT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 101 = Control Word 5 |
| 36 | Update | $0=$ No Control Register Update <br> 1 = Control Register Update |
| 35-21 | HDF <br> Decimation <br> Rate | HDF Decimation Factor Minus <br> 1. Minimum Allowable Value $=$ <br> 15. Bits $35-21=2^{14} \ldots 2^{0}$. <br> Decimate by 32,768: Bits 35-21 <br> = All Ones |
| 20-5 | Scaling Multiplier Gain | 16 Bit Gain Compensation Number With Values Between 0 and 2, 2 Non Inclusive. Bits $20-5=2^{0} .2^{-1} \ldots 2^{-15}$. |
| 4-3 | Output Format | $\begin{aligned} & 00=\text { Two's Complement } \\ & 01=\text { Offset Binary } \\ & 10=\text { Sign Magnitude } \\ & 11=\text { Single Precision Floating } \\ & \text { Point Format } \end{aligned}$ |
| 2-1 | Number Of Output Bits | $\begin{aligned} & 00=16 \text { Bits } \\ & 01=24 \text { Bits } \\ & 10=32 \text { Bits } \\ & 11=38 \text { Bits } \end{aligned}$ |
| 0 | Output Sense | $\begin{aligned} & 0=\text { LSB First } \\ & 1=\text { MSB First } \end{aligned}$ |

TABLE 7. FORMAT FOR CONTROL WORD 6 - INPUT, OUPUT FORMATS

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 110 = Control Word 6 |
| 36 | Update | $0=$ No Control Register Update <br> 1 = Control Register Update |
| 35 | I followed by Q | $0=I$ and $Q$ output separately $1=I$ and $Q$ data output on $\mid$ pin |
| 34-29 | Time Slot Number | Bits $34-29=2^{5} \ldots . .2{ }^{0}$. |
| 28 | IQCLK <br> Polarity | $0=$ Output Data Stable On Rising Edge Of IQCLK; IQCLK high between I or Q bit periods when IQCLK Duration $=0$. 1 = Output Data Stable On Falling Edge Of IQCLK; IQCLK low between I or Q bit periods when IQCLK Duration $=0$. |
| 27 | IQCL.K Duty Cycle | $\begin{aligned} & 0=\text { IQCLK Active Time }=\text { CLK } \\ & \text { period. } \\ & 1=50 \% \text { Duty Cycle } \end{aligned}$ |
| 26 | IQCLK <br> Duration | $0=$ Active During I or Q bit periods only <br> $t=$ Active continuously |
| 25-24 | IQCLK Three State Control | ```00 = Three State IQCLK 01 = Enable IQCLK 1x = Auto-Three State Enable IQCLK``` |
| 23 | IOSTB <br> Polarity | $\begin{aligned} & 0=\text { Active High } \\ & 1=\text { Active Low } \end{aligned}$ |
| 22 | IQSTB <br> Location | $0=$ IQSTB prior to the beginning of the data word. 1 = IQSTB during the data word. |
| 21-20 | IQSTB Three State Control | $00=$ Three State IQSTB <br> $01=$ Enable IQSTB <br> 1x = Auto Three State Enable IQSTB |
| 19 | I Polarity | $\begin{aligned} & 0=\text { True data } \\ & 1=\text { Inverted Data } \end{aligned}$ |
| 18-17 | IThree State Control | $\begin{aligned} & \infty=\text { Three State } 1 \\ & 01=\text { Enable } 1 \\ & 1 x=\text { Auto Three State Enable } 1 \end{aligned}$ |
| 16 | Q Polarity | $\begin{aligned} & 0=\text { True data } \\ & 1=\text { Inverted data } \end{aligned}$ |
| 15-14 | Q Three State Control | $\begin{aligned} & 00=\text { Three State } Q \\ & 01=\text { Enable } Q \\ & 1 x=\text { Auto Three State Enable Q } \end{aligned}$ |
| 13 | Input Format | $\begin{aligned} & 0=\text { Offset Binary } \\ & 1=\text { Two's Complement } \end{aligned}$ |
| 12-0 | IQCLK Rate | I/QCLK Rate, Bits 12-0 = $2^{12} . . .2^{0}$. |

TABLE 8. FORMAT FOR CONTROL WORD 7 -TEST FEATURES

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 111 = Control Word 7 |
| 36 | Update | $0=$ No Control Register Update 1 = Control Register Update |
| 35-14 | Reserved | All zeroes |
| 13 | Data | $0=$ Normal Data Input <br> 1 = Force Input Data to 8000 Hex. |
| 12-11 | FiR Accumulator Control | $\begin{aligned} & 00=\text { Normal Accumulation } \\ & 01=\text { No Accumulation } \\ & 10=\text { Continuous Accumulation } \\ & 11=\text { Reserved } \end{aligned}$ |
| 10 | Q Strobe on Roll Over | $0=Q$ carries normal data <br> 1 = Q Strobes When Phase <br> Generator Rolls Over |
| 9 | Force Outputs | $0=\text { Normal Output Response }$ $1 \text { = Force Outputs }$ |
| 8 | IQCLK Forced Data | If Bit $9=1$, Force IQCLK = Bit 8 ; Else Normal |
| 7 | IQSTB Forced Data | If Bit $9=1$, Force IQSTB $=$ Bit 7; Else Normal. |
| 6 | I Forced Data | If Bit $9=1$, Force I = Bit 6; Else Normal. |
| 5 | Q Forced Data | If Bit $9=1$, Force $Q=$ Bit 5 ; Else Normal. |
| 4-3 | Bypass | If Bit $\mathbf{4} \mathbf{= 0} \mathbf{~ S i n ~ C o s ~ G e n e r a t o r ~}$ Normal, if Bit $4=1$ bypass. If Bit $3=0$ Scaling Multiplier Normal, if Bit $3=1$, then scale factor $=1$. |
| 2 | Reserved | Must be zero for proper operation while Test Features are enabled. |
| 1 | Wait For RAM Full | If Bit $=0$, DDC will output data normally after a reset, which will include unpredictable data in data RAMs. If bit $=1$, no chip output will occur until sufficient data RAM locations are written. |
| 0 | Disable Overflow Protection | $\begin{aligned} & 0=\text { Normal Operation } \\ & 1=\text { Disable Overflow Protection } \end{aligned}$ |

When set for fixed point output, the output data can be in two's complement, offset binary or signed magnitude form. Data is converted to offset binary by complementing the most significant bit of a two's complement number. The length of the output data word can be 16, 24, 32 or 38 bits. The first three options are symmetrically rounded to the LSB of the output data; the fourth option represents the full 38 bit wiuth of tilié ácucurinulaior and so represenis exaci aritinmenic.
The output has a saturation option to prevent possible overflow due to a step input at power up. When Overflow Protection is enabled the output is forced to be either the most positive or most negative number. Saturation is available in all four fixed point output options.

Data can also be output in single precision floating point format. (See Table 9.) For all output data formats, the internal calculations are performed in exact two's complement integer arithmetic and the resulting data is converted in the Output Formatter.

TABLE 9. FLOATING POINT FORMAT

| SIGN | EXPONENT | MANTISSA |  |
| :---: | :---: | :---: | :---: |
| $-2^{0}$ | $2^{7}$ to $2^{0}$ | Implied 1 | $0.2^{-1}$ to $2^{-23}$ |

The I and Q pins can be programmed for either simultaneous or I followed by Q output. In simultaneous mode, the I and $Q$ data appear on the $I$ and $Q$ pins, respectively. Each data sample is preceded by a leading zero bit, followed by the output data, followed by a trailing zero bit. In I followed by Q mode, the output data appears on the I pin, and consists of a leading zero bit, then the I data, a trailing zero, a leading zero, the Q data, and finally a trailing zero bit. In Figure 10 and Figure 11, the leading and trailing zero bits occur before bit 0 and after bit $N$, respectively.

IQCLK is used to delineate the bit or word timing of the I and Q outputs. There are several options on the configuration of IQCLK, which are controlled with Control Word 6 (See Table 7). The frequency of IQCLK is programmed to be a fraction of the CLK frequency, from (CLK rate)/2 to (CLK rate)/8192 (See equation 7). If IQCLK Rate $=0$, then IQCLK remains in its inactive state and the output bits change on the rising edges of CLK.
IQCLK Rate $=\frac{\text { CLK }}{\text { IQCLK Frequency }}-1$

B. IQCLK DUTY CYCLE: $50 \%$

c. IGCLK DURATION: CONTINUOUS

D. IQCLK DURATION: ACTIVE DURING I OR Q ONLY

FIGURE 10. TIMING FOR CLK, IQCLK, IQSTB, I AND Q

IQCLK can be programmed to be active only during I or Q output or it can be active continuously with the IQCLK Duration bit. Using the IQCLK Duty Cycle bit, IQCLK is selectable as either $50 \%$ duty cycle or to be high for one period of CLK. In addition, the Formatter can be set so that the data bits are clocked on either the positive or negative edges of IQCLK with the IQCLK Polarity bit. Figure 10 shows the various modes of operation with IQCLK Polarity programmed for active high operation.

Control word 6 also configures IQSTB, as shown in Figure 11. When programmed for Active Prior to Data Word, IQSTB is high for one period of IQCLK and terminates simultaneously with the beginning of the first data bit; otherwise it goes active with the beginning of the first bit and inactive with the end of the last bit. IQSTB can be programmed to be either active high or low.

B. IQSTB ACTIVE DURING DATA WORD

FIGURE 11. IQSTB TIMING


FIGURE 12. REQUESTED DATA OUTPUT TIMING


FIGURE 13. CONTROL WORD TIMING DIAGRAM

Data can be read out of the DDC on request through the use of the IQSTRT\# pin. After passing through the Formatter, the $I$ and $Q$ data are stored in output buffers, which are updated at the end of the FIR Filter processing cycle. The IQSTRT\# and IQSTB lines form a two line handshake as shown in Figure 12. IQSTRT\# initiates the request. If the buffer has data in it, the DDC will begin an output data sequence on the next edge of IQCLK. The DDC will then put out one bit per IQCLK until the output cycle is complete. In I followed by Q mode, one IQSTRT\# will initiate an I output word followed by a Q output word. In real data output mode, one IQSTRT\# will initiate two samples of real data on the I pin.
To avoid the generation of multiple read cycles, IQSTRT\# must go inactive within 10 cycles of IQCLK after the initiation of IQSTB. The DDC will not update the output buffer again until the current output cycle has completed. When IQSTRT\# is used in this handshake mode, it must consist of pulses that satisfy the set up and hold requirements listed in the AC Timing Specifications and the pulses must occur at a rate of CLK/(HDF Decimation x4-1). This mode of operation requires the Time Slot Number in control word 6 to be 0.

When handshake mode is not used, IQSTRT\# should be at a logic low.

Auto Three State mode for IQCLK, IQSTB, I and Q allows multiple chips to operate using common data and output control lines. Each chip is assigned a Time Slot Number on the bus to use for outputting its data. All outputs programmed for Auto Three State Mode are active during their time slot and are in a high impedance state at all other times. A time slot starts one CLK period prior to the beginning of the first bit of I or Q and ends (Time Slot Length) CLK periods afterwards. Assignment of a time slot is with reference to the deassertion of RESET\#. The minimum possible Time Slot Length for a given application is:

$$
\begin{equation*}
\text { Length }_{\min }=[(\text { Number of Output Bits }+2) \times \text { Mode }]+1 \tag{8}
\end{equation*}
$$

Where Mode $=2$ if the DDC is in either Real Output or 1 Followed By Q mode; else Mode = 1 .

Note that equation 8 is useful in all modes for calculating the number of IQCLKs necessary to complete one output data cycle. For a given decimation rate and output word length, the maximum value in the IQCLK Rate field is:
IQCLK Rate $_{\text {max }}=$ Floor $\left[\frac{(\text { HDF Decimation }) \times 4}{\text { Length }_{\min }}\right]-1$
Where $\operatorname{Floor}(X)$ represents the integer part of $X$.

## Control Word Input

The DDC has eight 40 bit control words which are loaded through the four pin control interface. The format and timing of this interface is compatible with the serial interface timing of most common DSP microprocessors (See Figure 13). The words are shifted MSB first, where bit 39 of the control word is the MSB. Bits 39 through 37 are the control word address, i.e. the target control buffer. CS\# must go low before bit 35 is clocked in. All 40 bits of the control word must be loaded. The formats of the control words are shown in Tables 1 through 8.

The control words are double buffered: each control word is initially loaded into one of eight control buffers for subsequent down loading into the corresponding control register. The internal circuitry of the DDC uses the control registers to regulate its operation. Control buffers can be downloaded in one of two ways. Loading a buffer register with bit $36=1$ causes all control registers to be updated from their respective control buffers when the current word is finished loading. If bit $36=0$, then only that control buffer is updated and the operation of the DDC is not affected. All control registers are updated from their respective buffers on the third rising edge of CLK following the deassertion of RESET\#. Note that Control Word 0 is unique in that it is only used to update the seven control registers, and it is recognized by the DDC regardless of the state of CS\#. In systems with multiple DDCs, this allows the user to update the configuration of all chips simultaneously without using RESET\#.

To ensure that the control information is properly loaded, the frequency of CLK must be greater than the frequency of CCLK. In addition, RESET\# must remain inactive during the loading of a control word.

## Test

The HSP50016 supports two types of testing. Control Word 7 can be used to verify the operation of the circuit through the divide and conquer method. Setting the Enable Test Bit (Control Word 1, bit 3) equal to a 1 enables the test features controlled by Control Word 7. (This bit is in Control Word 1 so that Word 7 does not have to be loaded if the test features are not being used.) The functions allowed by Control Word 7 are shown in table 8.

The DDC also has a Test Access Port (TAP). This port is full conformant to IEEE Std. 1149.1-1990 - IEEE Standard Test Access Port and Boundary-Scan. [2] The TAP supports the following instructions: BYPASS, SAMPLE/PRELOAD, INTEST, EXTEST, RUNBIST and IDCODE. In addition, there are seven instructions called RDCNTLWD1-7, which read the contents of the control words over the TAP. The address bits and bit 36 are only used to determine the destination of data during loading; they are not stored, so they are not read out with this instruction.

The full description of the operation to the DDC while under the control of the TAP will be published in a separate document.

## Applications

## Down Conversion

The primary spectral operation in the DDC is down conversion of an input signal to base band. See Figure 14. This process is done in two steps: multiplication of the input waveform by an intcrinaliy yerietateú quadraiure sinusoid, i.e., modulation and lowpass filtering to attenuate the unwanted spectral components. The unwanted spectral components have two sources, the input signal and an artifact of the modulation process.

The modulation process can be written as:

$$
u(n)=x(n) e^{-j \omega_{c}}=x(n)\left[\cos \left(\omega_{c}\right)-j \sin \left(\omega_{c}\right)\right]
$$

Where $x(n)$ is the real input data sequence, $\omega=2 \pi f$, and $\omega_{c}$ is the frequency of the signal generated by the SIN/COS Generator.

For demonstration purposes let $x(n)=\cos \left(\omega_{k} n\right)$. The multiplication then becomes:

$$
\begin{aligned}
u(n)= & \cos \left(\omega_{k} n\right)\left[\cos \left(\omega_{c} n\right)-j \sin \left(\omega_{c} n\right)\right] \\
= & 1 / 2\left[\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+\cos \left(\left(\omega_{k}+\omega_{c}\right) n\right)\right. \\
& \left.-j\left(\sin \left(\left(\omega_{k}+\omega_{c}\right) n\right)-\sin \left(\left(\omega_{k}-\omega_{c}\right) n\right)\right)\right]
\end{aligned}
$$

The signal $u(n)$ is passed through a low pass filter; assuming that the filter passes the low frequency terms with no degradation and attenuates the high frequency terms completely, the filtering operation produces the output:

$$
\begin{aligned}
v(n) & =1 / 2\left(\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+j \sin \left(\left(\omega_{k}-\omega_{c}\right) n\right)\right) \\
& =1 / 2 \theta^{j\left(\omega_{k}-\omega_{c}\right) n}
\end{aligned}
$$

When the magnitude of the input signal $x(n)$ is one, the magnitude of $v(n)$ is $1 / 2$. Both the $I$ and $Q$ channels are multiplied by a factor of two to yield:

$$
\begin{aligned}
w(n) & =\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+j \sin \left(\left(\omega_{k}-\omega_{c}\right) n\right) \\
& =\theta^{i\left(\omega_{k}-\omega_{c}\right) n .}
\end{aligned}
$$

Figure 15 shows an HSP50016 in a single channel down conversion circuit. Notice that the input data is only 12 bits, so it is justified to the MSB of the DDC's input data. If a smaller sample width is used, it is recommended that the MSB of the data is input into DATA15, and the unused bits are connected to ground. This alignment makes it easier to locate the position of the MSB in the output data. Note that the input is configured for offset binary arithmetic and the output is set up for I followed by Q , which enables the use of only one serial connection to the output processor. The serial data clock of the processor and the Control Clock of the DDC are driven by a TTL compatible oscillator. (IQCLK cannot be used for this purpose since its frequency is indeterminate until the DDC has been configured.) Note that many processors provide a bit clock which eliminates the need for the external oscillator.


FIGURE 15. CIRCUIT FOR SINGLE CHANNEL OPERATION

An example of the control word contents for this mode of operation is given in Tables 10-15. In this setup, the DDC has been configured for a constant down conversion frequency, decimation by 64 and Test Features disabled. Bit fields of three bits or less are in binary notation; longer fields are in hexadecimal. Control words zero and seven are not used.
TABLE 10. SAMPLE FORMAT FOR CONTROL WORD 1-PHASE GENERATOR / TEST ENABLE

| BIT <br> POSITION | FUNCTION | DESCRIPTION |
| :--- | :--- | :--- |
| $39-37$ | Address | $001=$ Control Word 1 |
| 36 | Update | $1=$ Control Register Update |
| $35-4$ | Minimum Phase <br> Increment | Minimum Phase Increment <br> Computed according to <br> Equation 1. |
| 3 | Test Enable | $0=$ Test Features Disabled |
| $2-0$ | Phase Generator <br> Mode | $001=$ Normal Mode |

TABLE 11. SAMPLE FORMAT FOR CONTROL WORD2-PHASE GENERATOR

| BIT <br> POSITION | FUNCTION | DESCRIPTION |
| :--- | :--- | :--- |
| $39-37$ | Address | $010=$ Control Word 2 |
| 36 | Update | $0=$ No Control Register Update <br> $1=$ Control Register Update |
| $35-32$ | Reserved | All zeroes |
| $31-0$ | Maximum Phase <br> Increment | All zeroes |

TABLE 12. SAMPLE FORMAT FOR CONTROL WORD3-PHASE GENERATOR / OUTPUT TIME SLOT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 011 = Control Word 3 |
| 36 | Update | 1 = Control Register Update |
| 35-32 | Reserved | All zeroes |
| 31-18 | Time Slot Length | All zeroes |
| 17-0 | Phase Offset | All zeroes |

TABLE 13. SAMPLE FORMAT FOR CONTROL WORD 4-PHASE GENERATOR / HDF / OUTPUT

| BIT <br> POSITION | FUNCTION | DESCRIPTION |
| :--- | :--- | :--- |
| $39-37$ | Address | $100=$ Control Word 4 |
| 36 | Update | $1=$ Control Register Update |
| $35-33$ | Reserved | All zeroes |
| 32 | Up Convert | $0=$ Do not up convert |
| 31 | Real Mode | $0=$ Complex Mode |
| $30-7$ | Delta Phase <br> Increment | All zeroes |
| $6-1$ | Shift | $37=$ Decimal 55, the shift <br> corresponding to HDF decima- <br> tion by 16 |
| 0 | Spectral Reverse | $0=$ No spectral reversal |

TABLE 14. SAMPLE FORMAT FOR CONTROL WORD 5 - HDF I OUPUT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 101 = Control Word 5 |
| 36 | Update | 1 = Control Register Update |
| 35-21 | HDF Decimation | $F=$ Decimation by 16 in HDF |
| 20-5 | Scaling Multiplier Gain | 8000 = Scaling Multiplier Gain of 1. |
| 4-3 | Output Format | $00=$ Two's Complement |
| 2-1 | Number of Output Bits | $00=16$ Bits |
| 0 | Output Sense | 1 = MSB First |

TABLE 15. SAMPLE FORMAT FOR CONTROL WORD 6 OUTPUT

| $\begin{gathered} \text { BIT } \\ \text { POSITION } \end{gathered}$ | FUNCTION | DESCRIPTION |
| :---: | :---: | :---: |
| 39-37 | Address | 110 = Control Word 6 |
| 36 | Update | 1 = Control Register update |
| 35 | 1 followed by Q | $1=1$ and Q data output on I pin |
| 34-29 | Time Slot | Time Slot number $=0$ |
| 28 | IQCLK Polarity | $0=$ Data stable on rising edge of IQCLK |
| 27 | IQCLK Duty Cycle | 1 = IQCLK duty cycle is $50 \%$ |
| 26 | IQCLK Duration | 1 = Active continuously |
| 25-24 | IQCLK Three State Control | 01 = Enable IQCLK |
| 23 | IQSTB Polarity | $0=1$ ISTB active high |
| 22 | IQSTB Location | $0=$ IQSTB active prior to the beginning of the data word. |
| 21-20 | IQSTB Three State | 01 = Enable IQSTB |
| 19 | 1 Polarity | $0=1$ output active high |
| 18-17 | 1 Three State Control | 01 = Enable l |
| 16 | Q Polarity | $0=$ Q output active high |
| 15-14 | Q Three State Control | $00=$ Disable Q |
| 13 | Input Format | 1 = Two's complement |
| 12-0 | IQCLK Rate | All zeroes = CLK used to clock output bits |

## Quadrature To Real Conversion

After the input data has been processed by the DDC, the output can be converted into a real signal if desired. In that case, the baseband centered quadrature signal is upconverted so that the bottom of the spectrum is at baseband. The real part of the upconverted signal is taken as the output. To satisfy the Nyquist criteria, the sample rate of the resulting signal must be at least twice the minimum sample rate of the $I$ and $Q$ components of the quadrature signal. This prevents one sideband from aliasing onto the other sideband when the real part of the output signal is taken.

The spectrum of a quadrature signal which has been over sampled by 2 is shown in Figure 16a. This represents the output of the filters. As described in the previous paragraph, the oversampling is a necessary feature of this process, since the final signal will occupy twice the bandwidth of the filter output. To prevent aliasing upon taking the real part of the signal, it is necessary to perform an up conversion by $\mathrm{f}^{\boldsymbol{\prime} /}$ 4 , where $f^{\prime \prime}$ is the decimated sample frequency. (Note that $f_{s}$ is defined as the input sampling frequency, $f^{\prime}$ is the input sampling frequency divided by the HDF decimation rate R, and $f^{\prime \prime}$ is $f^{\prime}$ divided by the FIR decimation rate. $f^{\prime \prime}$ is the output sampling rate.) The up conversion function is:

$$
e^{j 2 \pi n n^{\prime} / 4 r^{\prime \prime}}=e^{j \pi n / 2}
$$

For $n=0,1,2,3,4, \ldots$ the output values of the local oscillator in rectangular representation are: $1+0 \mathrm{j}, 0+\mathrm{j},-1+0 \mathrm{j}, 0-\mathrm{j}, 1$ $+0 j$,... Since the real half of the complex multiplication of the local oscillator values by the filtered signal values (the desired output is the real part of the product) require only trivial operations, this up conversion is done in the Formatter. Figure 16b shows the signal spectrum after up conversion. Figure 16c shows the spectrum of the real output signal.

Continuing with the single tone example from the previous section, the quadrature signal output from the FIR fiters is:

$$
\begin{aligned}
w(n) & =\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+j \sin \left(\left(\omega_{k}-\omega_{c}\right) n\right) \\
& =\theta^{j\left(\omega_{k}-\omega_{c}\right) n}
\end{aligned}
$$

Multiplying $w(n)$ by the up convert function and summing the result is equivalent to the output sequence:

$$
\begin{aligned}
& y(n)=1 \times \cos \left(\left(\omega_{k}-\omega_{c}\right) n\right), \\
& y(n+1)=j \times j \sin \left(\left(\omega_{k}-\omega_{c}\right)(n+1)\right), \\
& y(n+2)=-1 \times \cos \left(\left(\omega_{k}-\omega_{c}\right)(n+2)\right), \\
& y(n+3)=-j \times j \sin \left(\left(\omega_{k}-\omega_{c}\right)(n+3)\right), \\
& y(n+4)=1 \times \cos \left(\left(\omega_{k}-\omega_{c}\right)(n+4)\right), \ldots \\
& y=\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right),-\sin \left(\left(\omega_{k}-\omega_{c}\right)(n+1)\right), \\
& \quad-\cos \left(\left(\omega_{k}-\omega_{c}\right)(n+2)\right), \sin \left(\left(\omega_{k}-\omega_{c}\right)(n+3)\right), \\
& \quad \cos \left(\left(\omega_{k}-\omega_{c}\right)(n+4)\right), \ldots
\end{aligned}
$$

Or:

$$
\begin{aligned}
y= & \operatorname{RE}(w(n)),-I M(w(n+1)),-\operatorname{RE}(w(n+2)), I M(w(n+3)), \\
& \operatorname{RE}(w(n+4)), \ldots
\end{aligned}
$$

Since $\left|e^{j \pi n / 2}\right|=1$ and $|w(n)|=1$, no further magnitude corrections are required.

The setup for this application is similar to that of the down conversion circuit given above, except the Output Formatter is set for Real Mode (bit 31 in Control Word 4). This bit configures the part for up conversion by $f^{\prime \prime} / 4$ and summing of the real and imaginary parts of the filter output.

## Up Conversion by f"/2

This eperatioūi allüws itie user to exchange the positions of the upper and lower halves of a down converted signal while leaving each half unchanged. Quadrature up conversion by $f^{n} / 2$ is performed by multiplying the output signal by $\mathrm{e}^{\mathrm{j} 2 \pi n n^{1 / 2}}=$ $\cos \left(2 \pi n f^{n} / 2\right)+j \sin \left(2 \pi n f^{\prime \prime} / 2\right)$. When sampled at a rate of $f^{n}$, $\cos \left(2 \pi n f^{\prime \prime} / 2\right)$ takes on the values $1,-1,1,-1, \ldots$ and $\sin \left(2 \pi n n^{n /}\right.$ 2) always $=0$. Thus, the up convert LO sequence is:
$e^{j \pi n}=1+j 0,-1+j 0,1+j 0, \ldots$

This sequence is multiplied by the output of the I and Q branches of the filter:

$$
\begin{aligned}
w(n) & =\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+j \sin \left(\left(\omega_{k}-\omega_{c}\right) n\right) \\
& =\theta^{j\left(\omega_{k}-\omega_{c}\right) n},
\end{aligned}
$$

yielding an output sequence:

$$
\begin{aligned}
y= & (\operatorname{RE}(w(n)), \operatorname{IM}(w(n))), \\
& -\operatorname{RE}(w(n+1)),-\operatorname{IM}(w(n+1))), \\
& \operatorname{RE}(w(n+2)), i M(w(n+2))), \ldots
\end{aligned}
$$

The Formatter contains the circuitry to shift the quadrature output spectrum up by one half of the output sample frequency $f^{n}$. This operation is independent of the function of the Phase Generator and Mixer. The spectra of the outputs of the Filter and Formatter are shown in Figure 17.

The setup is identical to the down conversion configuration, except that the Up Convert bit is set in Control Word 4.

A. OUTPUT OF FIR FILTERS: SIGNAL OVERSAMPLED BY 2

B. FIRST OPERATION IN FORMATTER: UP CONVERT BY SAMPLE FREQUENCY/4


## C. SECOND OPERATION IN FORMATTER: I OUTPUT $=1+Q$

FIGURE 16. QUADRATURE TO REAL CONVERSION OF AN OUTPUT SIGNAL

## Quadrature Spectral Reversal

Spectral reversal is often used to negate a spectral reversal which has occurred due to a previous operation in the processing chain. Examples of this are spectral reversal in an analog down conversion or in a constructive aliasing operation. The DDC gives the user the ability to convert the signal to baseband in either forward or reverse fashion. Quadrature spectral reversal is achieved by translating the lower sideband of the input to baseband rather than the upper sideband. This is implemented in the DDC by mixing the input signal with $e^{j 2 \pi t} c^{n}-$ that is, up converting the input rather than down converting it. The resulting signal is:

$$
u(n)=x(n) e^{\mathrm{j} 2 \pi f} c^{n}=x(n)\left[\cos \left(\omega_{c} n\right)+j \sin \left(\omega_{c} n\right)\right]
$$

Assuming $x(n)=\cos \left(\omega_{k} n\right)$,

$$
\begin{aligned}
u(n) & =\cos \left(\omega_{k} n\right)\left[\cos \left(\omega_{c} n\right)+j \sin \left(\omega_{c} n\right)\right] \\
& =\left[\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)+\cos \left(\left(\omega_{k}+\omega_{c}\right) n\right)\right. \\
& \left.+j\left(\sin \left(\left(\omega_{k}+\omega_{c}\right) n\right)-\sin \left(\left(\omega_{k}-\omega_{c}\right) n\right)\right)\right]
\end{aligned}
$$

After quadrature filtering and correcting for the gain of $1 / 2$, we have:

$$
\begin{aligned}
& w(n)=\cos \left(\left(\omega_{k}-\omega_{c}\right) n\right)-j \sin \left(\left(\omega_{k}-\omega_{c}\right) n\right) \\
& =\cos \left(-\left(\omega_{k}-\omega_{c}\right) n\right)+j \sin \left(-\left(\omega_{k}-\omega_{c}\right) n\right) \\
& =\cos \left(\left(\omega_{c}-\omega_{k}\right) n\right)+j \sin \left(\left(\omega_{c}-\omega_{k}\right) n\right) \\
& =e^{j\left(\omega_{c} c^{-} \omega_{k}\right) / n} \\
& \text { A. OUTPUT OF FIR FILTERS }
\end{aligned}
$$

B. FLTER OUTPUT UP CONVERTED BY OUTPUT SAMPLE FREQUENCY $/ 2$

FIGURE 17. UP CONVERSION BY F" / 2

B. UP CONVERSION AND FLLTERING

The appropriate spectral plots are shown in Figure 18. In up conversion, the sine output of the SIN/COS Generator is negated so that the vector output of the Local Oscillator rotates counter clockwise. This is implemented by setting the Spectral Reverse bit in Control Word 4 to a one. Otherwise, the setup for this mode is the same as the one for down conversion.

## Real Spectral Reversal

Real spectral reversal is simply quadrature spectral reversal with quadrature to real conversion in the Formatter. The up converted and filtered signal $w(n)$ is upconverted again by $\mathrm{f}^{\prime \prime} /$ 4 in the Formatter.Each sideband of the result is spectrally reversed from the sidebands that would have been produced by down conversion with quadrature to real conversion. The output spectrum is shown in Figure 19.
The setup for this application is similar to that of down conversion, except in control word 4, where the Spectral Reverse and Real Output bits are set to one.

## High Decimation Filter Only

The DDC can be operated as a single high decimation filter. This is done by setting the Phase Generator to Filter Only and the Minimum Phase Increment and Phase Offset to 0. This multiplies the incoming data stream by a constant hexadecimal 3FFFF in the $I$ channel and 0 in the $Q$ channel. The HDF section of the circuit requires a minimum decimation rate of 16 to allow sufficient time for the FIR to compute its response. This mode of operation implements a filter which has a decimation rate from 64 to 131,072. The frequency response is shown in Figures 7, 8 and 9. Only the I output has valid data in this mode; the Q output should be set to high impedance state to reduce circuit noise.

A. OUTPUT OF FILTERS: SIGNAL OVERSAMPLED BY 2

B. FRST OPERATION IN FORMATTER: UP CONVERT BY SAMPLE FREQUENCY / 4

C. SECOND OPERATION IN FORMATTER: 1 OUTPUT $=1+Q$

FIGURE 19. QUADRATURE TO REAL CONVERSION OF AN OUTPUT SIGNAL

## Multichannel Operation

Several DDCs can be placed in parallel with each one operating on a different frequency band. To minimize wiring, their outputs can be configured so that they are connected over a common serial bus. Each DDC is assigned a time slot number (Control Word 6) and a time slot length (Control Word 3). Each DDC in turn controls the bus for long enough to output its data, then relinquishes the bus. The time slot assignment and length are programmed at configuration time. Up to 64 chips can be multiplexed in this manner.
Figure 20 shows a block diagram of this configuration. The DDCs are configured by the microprocessor by first writing a logical 0 to its Chip Select line. The control words are written to that part in any order. When the part has been configured, CS\# is written high again, and the next part is configured in the same manner. Collisions are prevented by programming each DDC with a unique Time Slot number, which holds its output from 0 to 63 output word times before transmission. Each part also has a Time Slot Length, whose minimum value is given in equation 8 . Note that a value greater than the minimum can be used to give the processor time to operate on the data
The corresponding configuration register setup is similar to that of single channel down conversion, except for the Auto Three State fields. In this example, the first DDC in the chain is set to drive IQCLK; the others have this output set for high impedance. (It makes no difference which DDC is chosen to be the one to drive IQCLK, but it must be active continuously.) The unused outputs are put in their high impedance condition on the other DDCs to minimize power consumption. Note also that this example shows all DDCs in I followed by Q mode so that only one data line to the microprocessor is necessary. Figure 21 gives the timing of the output data.

Alternatively, the processor can request data from each of the DDCs asynchronously. In this setup, Requested Output Mode is used. The Data Concentrator polls each channel individually and is responsible for insuring that each channel is polled before the output data is lost. The Data Concentrator is a custom circuit designed by the user. A block diagram of such a system is shown in Figure 22. The interface between the controller and the DDCs has been omitted for the sake of clarity.

## References

[1] Hogenauer, Eugene V., An Economical Class of Digital Filters for Decimation and Interpolation, IEEE Transactions on Acoustics, Speech and Signal Processing, April 1981
[2] IEEE Standard Test Access Port and Boundary-Scan Architecture, IEEE Std 1149.1-1990


FIGURE 20. CIRCUIT FOR MULTIPLE CHANNEL OPERATION (AUTO THREE STATE)


FIGURE 21. TIMING FOR MULTIPLE CHANNEL OPERATION (AUTO THREE STATE)


FIGURE 22. CIRCUIT FOR MULTIPLE CHANNEL OPERATION (REQUESTED OUTPUT)

## Absolute Maximum Ratings

| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +7.0 V |  |
| :---: | :---: |
| Input, Output or V/O Voltage | GND-0.5V to VCC +0.5 V |
| Storage Temperature Range . . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |
| Junction Temperature . . . . . . . . . . . $1755^{\circ} \mathrm{C}$ (PGA), $+150^{\circ} \mathrm{C}$ (PLCC) |  |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

## Reliability Information

| Thermal Resistance | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| :---: | :---: | :---: |
| PGA Package | $41^{\circ} \mathrm{C} / \mathrm{W}$ | $5^{\circ} \mathrm{C} / \mathrm{W}$ |
| PLCC Package | $35^{\circ} \mathrm{C} / \mathrm{W}$ | $13^{\circ} \mathrm{C} / \mathrm{N}$ |
| Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$ |  |  |
| PGA Package |  | .1.95W |
| PLCC Package |  | 2.28W |
| Gate Count |  | 0 Gates |

CALITION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

Operating Conditions

DC Electrical Specifications $\quad \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} 10+70^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Current | ICCOP | - | 394 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Max, CLK Frequency 52.6 MHz <br> Notes 1,2 |
| Standby Power Supply Current | $I_{\text {cCsB }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=$ Max, Outputs Not Loaded |
| Input Leakage Current | 1 | -500 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=M a x, \text { Input }=0 V \text { or } V_{C C} \\ & \text { TMS, TDI, TRST\# } \end{aligned}$ |
|  |  | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=\text { Max, Input }=0 \mathrm{~V} \text { or } \mathrm{V}_{\mathrm{Cc}} \\ & \text { All other inputs } \end{aligned}$ |
| Output Leakage Current | 10 | -10 | 10 | V | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | $v$ | $\mathrm{V}_{\text {cc }}=$ Max |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | $v$ | $\mathrm{V}_{\mathrm{Cc}}=\mathrm{Min}$ |
| Logical One input Voltage: CLK, TRST\# | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $V_{\text {cc }}=$ Max |
| Logical One Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Logical Zero Output Voltage | V OL | - | 0.4 | V | $\mathrm{IOL}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 10 | pF | CLK Frequency 1 MHz |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | 10 | pF | $=+25^{\circ} \mathrm{C}, \text { Note } 3$ |

## NOTES:

1. Power supply current is proportional to frequency. Typical rating is $7.5 \mathrm{~mA} / \mathrm{MHz}$. Note that operation at maximum clock frequency will exceed maximum junction temperature of device. Use of a heat sink and/or air flow is required under these conditions: recommended heat sink is EG\&G Wakefield D10650-40.
2. Output load per test circuit and $C L=40 \mathrm{pF}$.
3. Not tested, but characterized at initial design and at major process/design changes.

AC Electrical Specifications $\quad V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ}$ to $+70^{\circ} \mathrm{C}$, (Note 1)

| PARAMETER | SYMBOL | -52(52.6) MHz |  | PRELIMINARY $-75(76: 9) \mathrm{MHz}$ |  | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ | 19 | - | 13 | $\bigcirc$ | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 7 | - | 5 | - | ns |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 7 | - | 5 | $\stackrel{\rightharpoonup}{2}$ | ns |
| Setup Time DATAO-15 to CLK | $\mathrm{T}_{\mathrm{DS}}$ | 10 | - | 7 | - | ns |
| Hold Time DATA0-15 from CLK | $\mathrm{T}_{\mathrm{DH}}$ | 1 | - | 1 | - | ns |
| RESET\# Pulse Width | $\mathrm{T}_{\text {RL }}$ | $\mathrm{T}_{\mathrm{CP}+11}$ | - | Tcr+8 | $\bullet$ | ns |
| RESET\#, IQSTRT\# Setup Time from CLK | $\mathrm{T}_{\text {RS }}$ | 10 | - | 7 | $\stackrel{+}{+}$ | ns, Note 2 |
| RESET\#, IQSTRT\# Hold Time to CLK | $\mathrm{T}_{\text {RH }}$ | 1 | - | 1 | - | ns, Note 2 |
| CLK to I, Q, IQSTB, IQCLK Delay | $\mathrm{T}_{\mathrm{DO}}$ | - | 15 | $\cdots$ | 12 | ns |
| CCLK Period | $\mathrm{T}_{\text {CCP }}$ | 100 | - | 100 | , | ns |
| CCLK High | $T_{\text {cch }}$ | 40 | - | 40 | $\bullet$ | ns |
| CCLK Low | $\mathrm{T}_{\text {CCL }}$ | 40 | - | 40 | , | ns |
| CDATA, CSTB, CS\# Setup to CCLK | $\mathrm{T}_{\text {cDS }}$ | 30 | - | 30 | - | ns |
| CDATA, CSTB, CS\# Hold from CCLK | $\mathrm{T}_{\text {CDH }}$ | 30 | - | 30 | - | ns |
| CCLK Low Setup to CLK | $T_{\text {cls }}$ | 30 | - | 30. | - | ns, Notes 2, 3 |
| CCLK High Hold from CLK | $\mathrm{T}_{\mathrm{CHH}}$ | 30 | - | 30 | $\stackrel{+}{+}$ | ns, Notes 2, 3, 6 |
| TCK Period | $\mathrm{T}_{\text {TP }}$ | 100 | - | 100 | $\checkmark$ | ns, Note 4 |
| TCK High | $T_{T H}$ | 40 | - | 40 | - | ns |
| TCK Low | $\mathrm{T}_{\text {TL }}$ | 40 | - | 40 | - | ns |
| TRST\# Pulse Width | $\mathrm{T}_{\text {TRL }}$ | 100 | - | 100 | - | ns |
| TCK to TDO, Data delay | $T_{\text {TDO }}$ | - | 30 | , | 30 | ns |
| Setup Time On All Inputs to TCK | $\mathrm{T}_{\text {ATS }}$ | 30 | - | 30 | - | ns, Note 5 |
| Hold Time On All Inputs from TCK | $\mathrm{T}_{\text {ATH }}$ | 30 | - | 30 | $\pm$ | ns, Note 5 |
| TCK Setup Time to CLK | $\mathrm{T}_{\text {TCS }}$ | 30 | - | 30 | $\underline{ }$ | ns, Note 4 |
| TCK Hold Time from CLK | $\mathrm{T}_{\text {TCH }}$ | 30 | - | 30 | - | ns, Note 4 |
| Output Enable Time from CLK | $\mathrm{T}_{\mathrm{OE}}$ | - | 18 | $\cdots$ | 12 | ns, Note 6 |
| Output Disable Time from CLK | TOD | - | 18 | $\stackrel{1}{2}$ | 12 | ns, Note 6 |
| Output Enable time from TCK | Ttoe | - | 32 | $\cdots$ | 32 | ns, Note 6 |
| Output Disable time from TCK | $\mathrm{T}_{\text {TOD }}$ | - | 32 | $\bullet$ | 32 | ns, Note 6 |
| Output rise, fall time | $\mathrm{T}_{\mathrm{RF}}$ | - | 5 | $\pm$ | 5 | ns, Note 6 |

NOTES:

1. AC tests performed with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$, $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$, and $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$. Input reference level for CLK, TRST\# is 2.0 V , all other inputs 1.5 V . Test $\mathrm{V}_{I H}=3.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{H} \text { ! }}=4.0 \mathrm{~V}, \mathrm{~V}_{\text {II }}=0 \mathrm{~V}: \mathrm{V}_{\text {OU }}=\mathrm{V}_{\text {OL }}=2.5 \mathrm{~V}$
2. These are asynchronous inputs; setup and hold times must only be maintained in order to predict which clock cycle they take effect internally.
3. Timing must only be maintained when Update bit is active in control word data being loaded.
4. Special Timing relationship between TCK and CLK is required for Test Instructions RUNBIST, EXTEST and INTEST.
5. All inputs except TRST\#, and only when TCK is driving internal clock.
6. Controfled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

## AC Test Load Circuit



SWITCH S1 OPEN FOR ICCSB AND ICCOP
Waveforms



Digital Quadrature Tuner

## Features

- 10 bit Real or Complex Inputs
- Frequency Selectivity $\mathbf{< 0 . 0 1 4 H z}$
- Data Rates to 60MSPS
- Third Order Cascaded-Integrator-Comb (CIC) Filter configurable as Integrate and Dump Filter (First Order CIC ) or Bypassable
- Decimation from 1-4096, or Set by Resampling NCO used for Bit Synchronization
- Error Detection for External IF AGC Loop
- Internal AGC Loop for Output Level Stability
- Bi-Directional 8-Bit Microprocessor Interface
- Parallel or Serial Output Data Formats


## Applications

- Phase and Frequency Modulation
- VSAT, INMARSAT Systems


## Ordering Information

| PART <br> NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP50110JC-60 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |

## Description

The Digital Quadrature Tuner (DQT) provides many of the functions needed for digital demodulation. These functions include carrier L.O. generation, symbol clock generation, preselection filtering, baseband AGC, and IF AGC error detection. The DQT facilitates many different digital implementations of demodulator tracking loops, which allows this chip to handle multiple modes and/or data rates simply by loading a new set of control words.
The DQT accepts digitized signals in either a real or complex representation. The digitized band of interest is shifted to DC through a complex multiplication by an internally generated L.O. The quadrature LO is generated by a numerically controlled oscillator (NCO) with a tuning resolution of approximately 14 MHz at a clock rate of 60 MHz and a spurious free dynamic range of 60 dB . For added flexibility, a control interface is provided for real time phase and frequency updates.
The output of the complex multiplier is gain corrected and feed into identical preselection filters on both the real and imaginary processing legs. Each preselection filter is comprised of a decimating low pass filter followed by a compensation filter. The decimating low pass filter is a 3 stage cascade-integrator-comb (CIC) filter. The CIC filter can be bypassed, configured as an integrate and dump filter with a $\sin (X) / X$ response, or a third order filter with a $(\sin (X) / X)^{3}$ response. The decimation of the CIC filter stage may be fixed from 1-4096, or it may be controlled by a re-sampling NCO used for bit synchronization. The compensation filter is user selectable for flattening the $(\sin (X) / X)^{N}$ response of the CIC. These onboard filters may be bypassed if custom extemal filtering is required.
Level detectors are provided to generate error signals for extemal/internal AGC loops. The DQT output is provided in either serial or parallel formats to support interfacing with a variety DSP processors or digital filter components. This device is configurable over a general purpose 8-bit parallel bidirectional microprocessor control bus.

## SPECIAL FUNCTION

## PAGE

## SPECIAL FUNCTION DATA SHEETS

HSP45240 Address Sequencer ..... 7-3
HSP45240/883 Address Sequencer ..... 7-15
HSP45256 Binary Correlator ..... 7-21
HSP45256/883 Binary Correlator ..... 7-34
HSP9520, HSP9521 Multilevel Pipeline Registers. ..... 7-42

Address Sequencer

## Features

- Block Oriented 24-Bit Sequencer
- Configurable as Two Independent 12-Blt Sequencers
- $24 \times 24$ Crosspoint Switch
- Programmable Delay on 12 Outputs
- Multi-Chip Synchronization Signals
- Standard $\mu$ P Interface
- 100pF Drive on Outputs
- DC to 50MHz Clock Rate


## Applications

- 1-D, 2-D Filtering
- Pan/Zoom Addressing
- FFT Processing
- Matrix Math Operations


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP45240JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP45240JC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP45240JC-50 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PLCC |
| HSP45240GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP45240GC-40 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |
| HSP45240GC-50 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 68 Lead PGA |

## Description

The Harris HSP45240 is a high speed Address Sequencer which provides specialized addressing for functions like FFTs,1-D and 2-D filtering, matrix operations, and image manipulation. The sequencer supports block oriented addressing of large data sets up to 24-bits at clock speeds up to 50 MHz .

Specialized addressing requirements are met by using the onboard $24 \times 24$ crosspoint switch. This feature allows the mapping of the 24 address bits at the output of the address generator to the $\mathbf{2 4}$ address outputs of the chip. As a result, bit reverse addressing, such as that used in FFTs, is made possible.
A single chip solution to read/write addressing is also made possible by configuring the HSP45240 as two 12-bit sequencers. To compensate for system pipeline delay, a programmable delay is provided on 12 of the address outputs.
The HSP45240 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs, with the exception of clock, are TTL compatible.

Block Diagram


ADDRESS SEQUENCER HSP45240
68 PIN PLASTIC LEADED CHIP CARRIER (PLCC)


## Pin Descriptions

| NAME | TYPE | PLCC PIN NUMBER | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | 1 | $\begin{gathered} 6,24,34,41 \\ 49,55,68 \end{gathered}$ | +5V power supply pin. |
| GND | 1 | $\begin{gathered} 3,9,18,22 \\ 38,46,52 \\ 58,65 \end{gathered}$ | GROUND |
| RST\# | 1 | 25 | RESET: This active low input causes a chip reset which lasts for 26 clocks after RST\# has been de-asserted. The reset initializes the Crosspoint Switch and some of the configuration registers as described in the Processor Interface section. The chip must be clocked for reset to complete. |
| CLK | 1 | 23 | CLOCK: The "CLK" signal is a CMOS input which provides the basic timing for address generation. |
| WR\# | 1 | 19 | WRITE: The rising edge of this input latches the data/address on DO-6 to be latched into the Processor Interface. |
| CS\# | 1 | 21 | CHIP SELECT: This active "low" input enables the configuration data/address on DO-6 to be latched into the Processor Interface. |
| AO | 1 | 20 | ADDRESS 0: This input defines DO-6 as a configuration register address if "high", and configuration data if "low", (see Processor Interface text). |
| D0-6 | 1 | 11-17 | DATA BUS: Data bus for Processor Interface. |
| OEH\# | 1 | 28 | OUTPUT ENABLE HIGH: This asynchronous input is used to enable the output buffers for OUT12-23. |
| OEL\# | 1 | 29 | OUTPUT ENABLE LOW: This asynchronous input is used to enable the output buffers for OUTO-11. |
| STARTIN\# | 1 | 31 | START-IN: This active low input initiates an addressing sequence. May be tied to STARTOUT\# of another HSP45240 for multi-chip synchronization. STARTIN\# should only be asserted for one CLK because address sequencing begins after STARTIN\# is de-asserted. |
| DLYBLK | 1 | 30 | DELAY BLOCK: This active "high" input may be used to halt address generation on address block boundaries (see Sequence Generator text). The required timing relationship of this signal to the end of an address block is shown in Application Note 9205. |
| OUT0-23 | 0 | $\begin{gathered} 39,40,42,45, \\ 47,48,50,51, \\ 53,54,56,57, \\ 59,62-64,66, \\ 67,1,2,4,5 \\ 7,8 \end{gathered}$ | OUTPUT BUS: TTL compatible 24-bit Address Sequencer output. |
| BLOCKDONE\# | 0 | 36 | BLOCK DONE: This active low output signals when the last address in an address block is on OUTO-23. |
| DONE\# | 0 | 37 | DONE: This active low output signals when the last address of an address sequence is on OUTO-23. |
| ADDVAL\# | 0 | 33 | ADDRESS VALID: This active tow output signals when the first address of an address sequence is on OUTO-23. |
| STARTOUT\# | 0 | 32 | START-OUT: This active low output is generated when an address sequence is initiated by a mechanism other than STARTIN\#. May be tied to the STARTIN\# of other HSP45240's for multichip synchronization. |
| BUSY\# | 0 | 35 | BUSY: This active low output is asserted one CLK after RST\# is de-asserted and will remain asserted for 25 CLK's. While BUSY\# is asserted all writes to the Processor Interface are disabled. |

\# Denotes active low.

## Functional Description

The Address Sequencer is a 24-bit programmable address generator. As shown in the Block Diagram, the sequencer consists of 4 functional blocks: the start circuitry, the sequence generator, the crosspoint switch, and the processor interface. The addresses produced by the sequence generator are input into the crosspoint switch. The crosspoint switch maps 24 bits of address input to a 24 bit output. This allows for addressing schemes like "bitreverse" addressing for FFT's. A programmable delay block is provided to allow the MSW of the output to be skewed from the LSW. This feature may be used to compensate for processor pipeline delay when the sequence generator is configured as two independent 12 bit sequencers. Address Sequencer operation is controlled by values loaded into configuration registers associated with the sequence generator, crosspoint switch, and start circuitry. The configuration registers are loaded through the processor interface.

## Start Circuitry

The Start Circuitry generates the internal START signal which causes the Sequence Generator to initiate an addressing sequence. The START signal is produced by writing the Processor Interface's "Sequencer Start" address (see Processor Interface text), by asserting the STARTIN\# input, or by the terminal address of a sequence generated under "One-Shot Mode with Restart" (see Sequence Generator section). Care should be taken to assert STARTIN\# for only one clock cycle to insure proper operation. A programmable delay from 1 to 31 clocks is provided to delay the initiation of an addressing sequence by delaying the internal START signal (see Processor Interface text).
The Start Circuitry generates the output signal ADDVAL\# which is asserted when the first valid output address is at the pads. In addition, the Start Circuitry generates the "STARTOUT\#" signal for multichip syncronization. Note: STARTOUT\# is only generated when an addressing sequence is started by writing the "Sequencer Start" address of the Processor Interface, or an internal START is generated by reaching the end of an addressing sequence produced by "One-Shot Mode with Restart".

## Sequence Generator

The Sequence Generator is a block oriented address generator. This means that the desired address sequence is subdivided into one or more address blocks each containing a user defined number of addresses. User supplied configuration data determines the number of address blocks and the characteristics of the address sequence to be generated.
As shown in Figure 1, the Sequence Generator is subdivided into the an address generation and control section. The address generation section performs an accumlation based on the output of MUX1 and MUX2. The control section governs the operation of the multiplexers, enables loading of the Block Start Address register, and signals completion of an address sequence.
An address sequence is started when the control section of the Sequence Generator receives the internal START signal from the Start Circuitry. When the START signal is received, the control section multiplexes the contents of the Start

Address Register and a " 0 " to the adder. The result of this summation is the first address in the first block of the address sequence. This value is stored in the Block Start Address register by an enable generated from the control section, and the multiplexers are switched to feed the output of the Holding and Address Increment registers to the adder. Address generation will continue with the Address Increment added to the contents of the Holding Register until the first address block has been completed.
An address block is completed when the number of addresses generated since the beginning of the address block equals the value stored in the Block Size register. When the last address of the block is generated, BLOCKDONE\# is asserted to signal the end of the address block (see Application Note 9205). On the following CLK, the multiplexers are configured to pass the contents of the Block Start Address and Block Increment registers to the adder which generates the first address of the next address block. An enable from the control section allows this value to update the Block Start Address register, and the multiplexers are switched to feed the Holding and Address Increment registers to the adder for generation of the remaining addresses in the block.
The address sequence is completed when the number of address blocks generated equals the value loaded into the Number of Blocks register. When the final address in the last address block has been generated, DONE\# and BLOCKDONE\# are asserted to signal the completion of the address sequence.

The parameters governing address generation are loaded into five 24-bit configuration registers via the Processor interface. These parameters include the Start Address, the beginning address of the sequence; the Block Size, the number of addresses in the address block; the Address Increment, the increment between addresses in a block; the Number of Blocks, the number of address blocks in a sequence (minimum 1); the Block Increment, the increment between starting addresses of each block. The loading and structure of these registers is detailed in the Processor Interface text.


FIGURE 1. SEQUENCE GENERATOR BLOCK

Three modes of operation may be selected by loading the 6bit Mode Control register (see Processor Interface). The three modes of operation are:

1. One-Shot Mode without Restart Address generation halts after completion of the user specified address sequence. Address generation will not resume until the intemal START signal is generated by the Start Circuitry. When the final address in the final block of the address sequence is generated, both DONE\# and BLOCKDONE\# are asserted and the last address is held on OUTO-23 (See Application Note 9205). 2.
2. One-Shot Mode with Restart: This mode is identical to One-Shot Mode without Restart with the exception that the Start Circuitry automatically generates an internal START at the end of the user specified sequence to restart address generation. The end of the address sequence is signaled by the assertion of DONE\#, BLOCKDONE\#, and STARTOUT\# as shown in Application Note 9205. In this mode, the first address of the next sequence immediately follows the last address of the current sequence if start delay is disabled.
3. Continuous Mode: Address generation neverterminates. Address generation proceeds based on the Start Address, Address Increment, Block Size, and Block Increment Parameters. The Number of Blocks parameter is ignored, and the DONE\# signal is never asserted.
The Mode Control register is also used to configure the Sequence Generator for operation as two independent 12-bit address sequencers. In dual sequencer mode, the adder in the sequence generator suppresses the carry from the 12 LSBs to the 12 MSBs. With the carry suppressed, two independent sequences may be produced. These 12-bit address sequences may be delayed relative to each other by programming the Mode Control register for a delay up to 7 clocks. This feature is useful to compensate for pipeline delay when using dual sequencer mode to generate read/ write addressing.
The DLYBLK input can be used to halt address generation at the end of any address block within a sequence. In addition, DLYBLK can be used to delay an address sequence from restarting if asserted at the end of the final address block generated under "One-Shot Mode with Restart". See Application Note 9205 for the timing relationship of DLYBLK to the end of the address block required to halt address sequencing.

## Crosspoint Switch

The crosspoint switch is responsible for reordering the address bits output by the sequence generator. The switch allows any of its 24 inputs to be independently connected to any of its 24 outputs. The crosspoint switch outputs can be driven by only one input, however, one input can drive any number of switch outputs. If none of the inputs are mapped to a particular output bit, that output will be "low".
The input to output map is configured through the processor interface. The I/O map is stored in a bank of 24 configuration registers. Each register corresponds to one output bit. The output bit is mapped to the input via a value, 0 to 23 , stored in the register. After power-up, the user has the option of configuring the switch in 1:1 mode by using the reset input,
"RST\#". In 1:1 mode the cross-point switch outputs are in the same order as the input. More details on configuring the switch registers are contained in the Processor Interface text.

## Processor Interface

The Processor Interface consists of a 10 pin microprocessor interface and a register bank which holds configuration data. The data is loaded into the register bank by first writing the register address to the processor Interface and then writing the data. An auto address increment mode is provided so that a base address may be written followed by a number of data writes.
The microprocessor interface consists of a 7 bit data bus (DO6), a one bit address select (AO) to specify DO-6 as either address or data, a write input (WR\#) to latch data into the Processor Interiace, and a chip select input (CS\#) to enable writing to the interface. The Processor Interiace input is decoded as either data or address as shown by the bit map in Table 1.

TABLE 1.

|  | A0 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| REGISTER ADDRESSES |  |  |  |  |  |  |  |  |
| Switch Output Registers | 1 | $x$ | 0 | $n$ | $n$ | $n$ | $n$ | $n$ |
| Sequencer Starting <br> Address | 1 | $x$ | 1 | 0 | 0 | 0 | $n$ | $n$ |
| Sequencer Block Size | 1 | $x$ | 1 | 0 | 0 | 1 | $n$ | $n$ |
| Sequencer Number of <br> Blocks | 1 | $x$ | 1 | 0 | 1 | 0 | $n$ | $n$ |
| Sequencer Block | 1 | $x$ | 1 | 0 | 1 | 1 | $n$ | $n$ |
| Address Increment |  |  |  |  |  |  |  |  |
| Sequencer Address | 1 | $x$ | 1 | 1 | 0 | 0 | $n$ | $n$ |
| Increment |  |  |  |  |  |  |  |  |
| Mode Control | 1 | $x$ | 1 | 1 | 0 | 1 | 0 | 0 |
| Test Control | 1 | $x$ | 1 | 1 | 0 | 1 | 0 | 1 |
| Start Delay Control | 1 | $x$ | 1 | 1 | 0 | 1 | 1 | 0 |
| Address Sequencer <br> "START" | 1 | $x$ | 1 | 1 | 1 | 1 | 1 | 1 |
| DATA WORDS |  |  |  |  |  |  |  |  |
| Current Address Data | 0 | 0 | $n$ | $n$ | $n$ | $n$ | $n$ | $n$ |
| (no address increment) |  |  |  |  |  |  |  |  |
| Current Address Data <br> (address increment) | 0 | 1 | $n$ | $n$ | $n$ | $n$ | $n$ | $n$ |
| NOTES: |  |  |  |  |  |  |  |  |

1. Table 1 " $x$ " means "don't care", and " $n$ " denotes bits which are decoded as an address in address registers and data in data registers.
2. When WR" transitions "high" to write the Sequencer "Start" address (1x111111), it must remain high until after a rising edge of clock. Otherwise, the sequencer "start" signal will not be generated.
The register bank consists of a series of 6 bit registers which may be addressed individually as shown in Table 1. The data in these registers is down loaded into configuration registers in the Start Circuitry, Sequence Generator, and Crosspoint Switch when an address sequence is initiated by the internal START signal (see Start Circuitry). This double buffered architecture allows new configuration data to be down loaded to the Processor Interface while an address sequence is being completed using previous configuration data.

The register bank has five sets of four registers which contain address generation parameters. These parameters include: Address Start, Block Size, Number of Blocks, Block Increment, and Address Increment. Each register set maps to one of five 24-bit configuration registers in the Sequence Generator block (see Sequence Generator). The mapping of the 6-bit registers in the register bank to the 24-bit configuration registers is determined by the 2 LSB's of the register address. The higher the value of the 2 LSB's the higher the relative mapping of the 6-bit register to the 24-bit register. For example, if the 2 LSB's of the register address are both 0 , the register contents will map to the 6 LSB's of the configuration register.

The register bank has 24 registers which contain the data for Crosspoint Switch 1/O mapping. These registers are accessed via the 5 LSB's of the address for the Crosspoint Mapping registers in Table 1. A value from 0 to 23 accesses the mapping registers for OUTO-23 repectively. A value greater than 23 is ignored. The output bit represented by a particular register is mapped to the input by the 6-bit value loaded into the register. If the value loaded into the register exceeds 23, the correponding output bit will be " 0 ". For example, if the 5 LSB's of the Crosspoint Mapping address are equal to 3 , and the valued loaded into the register accessed by this address is equal to 23, OUT3 would be mapped to the MSB of the sequence generator output.

After a reset, the Mode Control, Test Control, and Start Delay registers are reset as described in the section describing each register's bit map; the Crosspoint Mapping registers are reset to a $1: 1$ crosspoint switch mapping; the registers which hold the five address generation parameters are not affected.

To save the user the expense of alternating between address and data writes, an auto address increment mode is provided. The address increment mode is invoked by performing data writes with a " 1 " in the D6 location of the data word as shown in Table 1. For example, the crosspoint switch could be configured by 25 writes to the Processor Interface (one write for the starting address of the crosspoint mapping registers followed by 24 data writes to those registers).

## Mode Control Register

The Mode Control Register is used to control the operation of the sequence generator. In addition, it also controls the output delay between the MSW and the LSW of OUTO-23. The following tables illustrate the structure of the mode control register.

TABLE 2. MODE CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110100$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D5 | D4 | D3 | D2 | D1 | D0 |
| OD2 | OD1 | OD0 | DS | M1 | M0 |

ODx - Output Delay: Delays OUTO-11 from OUT12-23 by the following number of clocks.

| OD2 | OD1 | ODO |  |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Output Delay of 0 |
| 0 | 0 | 1 | Output Delay of 1 |
| 0 | 1 | 0 | Output Delay of 2 |
| 0 | 1 | 1 | Output Delay of 3 |
| 1 | 0 | 0 | Output Delay of 4 |
| 1 | 0 | 1 | Output Delay of 5 |
| 1 | 1 | 0 | Output Delay of 6 |
| 1 | 1 | 1 | Output Delay of 7 |

DS - Dual Sequencer Enable: Allows two independent 12-bit sequences to be generated.


Mx - Mode: Sequencer Mode.

| M1 | M0 |  |
| :---: | :---: | :--- |
| 0 | 0 | One-Shot Mode without Restart |
| 0 | 1 | One-Shot Mode with Restart |
| 1 | $x$ | Continuous Mode $(x=$ don't care $)$ |

During reset, this register will be reset to all zeroes. This will configure the chip as a 24-bit sequencer with zero delays on the outputs. The chip will also be in one-shot mode without restart.

## Start Delay Control Register

The Start Delay Control Register is used to configure the start circuitry for delayed starts from 1 to 31 clock cycles. Internal "START", external "START", and restarts will be delay by the programmed amount. The structure of the Start Delay Control Register is shown in Table 3.
TABLE 3. START DELAY CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110110$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D5 | D4 | D3 | D2 | D1 | D0 |
| SDE | SD4 | SD3 | SD2 | SD1 | SD0 |

SDE - Start Delay Enable: Enables "START" to be delayed by the programmed amount. When Start Delay is enabled, a minimum of " 1 " is required for the programmed delay.

| 0 | Start Delay is Disabled. |
| :---: | :--- |
| 1 | Start Delay is Enabled. |

SDx - Start Delay: Delays the "START" by the deronar number of clocks.

| SD4 | SD3 | SD2 | SD1 | SD0 |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 1 | Start Delay of 1 |
| 0 | 0 | 0 | 1 | 0 | Start Delay of 2 |
| 0 | 0 | 0 | 1 | 1 | Start Delay of 3 |
| 1 | 1 | 1 | 1 | 1 | Start Delay of 31 |

During reset, this register will be reset to all zeros. This will bring the chip up in a mode with Start Delay disabled.

## Test Control Register

A Test Control Register is provided to configure the sequence generator to produce test sequences. In this mode, the sequence generator can be configured to multiplex out the contents of the down counters in the sequence generator control circuitry, Figure 2. These counters are used to determine when a block or sequence is complete. As shown in Figures 1 and 2, the MSW or LSW in the down counters is multiplexed to the MSW of the address generator output. In addition, a test mode is provided in which the sequence generator performs a shifting operation on the contents of the start address register. The structure of the Test Control Register is shown in Table 4.


FIGURE 2. SEQUENCE GENERATOR CONTROL

TABLE 4. TEST CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110101$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D 5 | D 4 | D3 | D2 | D1 | D0 |
| xx | xx | SE | COE | CS1 | CSO |

Bits "D5" and "D6" are currently not used.

SE - Shifter Enable: Input to crosspoint switch is generated by shifting Start Address Register one bit per clock.

| 0 | Sequence Generator Functions Normally |
| :---: | :--- |
| 1 | Sequence Generator Functions as Shift Register |

COE - Counter Output Enable: Enable contents of down counters in the sequence generator control circuitry to be muxed to the 12 MSB's of the address generator output.

| 0 | Disable Muxing of down counters |
| :---: | :--- |
| 1 | Enable Muxing of down counters |

CS - Counter Select: Selects which 12-bit word of the down counters is muxed to the MSW of the address generator output.

| CS1 | CSO |  |
| :---: | :---: | :--- |
| 0 | 0 | Select Counter \#1, bits 0-11 |
| 0 | 1 | Select Counter \#1, bits 12-23 |
| 1 | 0 | Select Counter \#2, bits 0-11 |
| 1 | 1 | Select Counter \#2, bits 12-23 |

During reset, this register will be reset to all zeroes. This will bring the chip up in the mode with all of the test features disabled.

## Applications

## Image Processing

The application shown in Figure 3 uses the HSP45240 Address Sequencer to satisfy the addressing requirements for a simple image processing system. In this example the controller configures the sequencers to generate specialized addressing sequences for reading and writing the frame buffers. A typical mode of operation for this system might be to perform edge detection on a sub-section of an image stored in the frame buffer. In this application, data is fed to the 2-D Convolver by the address sequence driving the input frame buffer.

A graphical interpretation of sub-image addressing is shown in Figure 4. Each dot in the figure corresponds to an image pixel stored in memory. It is assumed that the pixel values are stored by row. For example, the first 16 memory locations would contain the first row of pixel values. The 17th memory location would contain the first pixel of the second row.


FIGURE 3. IMAGE PROCESSING SYSTEM


FIGURE 4. SEQUENCER SUB-IMAGE ADDRESSING

The sub-image address sequence shown in Figure 3 is generated by configuring the sequence generator with the following:

1. Start Address

$$
=35
$$

4. Step Size
$=1$
5. Block Size
$=8$
6. Block Step Size
$=16$
7. Number of Blocks $=8$

In this example the start address corresponds to the address of the first pixel of the first row. The row length corresponds to the Block Size which is programmed to 8. Within the block, consecutive addresses are generated by programming the Step Size to 1. At the completion of first block of addresses, the Block Step Size of 16 is added to the Start Address to generate the address of the first pixel of the second row. Finally, 8 rows of addressing are generated by setting the Number of Blocks to 8 .

In this application, the sub-image is processed one time and then a new sub-image area is chosen. As a result, the Mode Control Register would be configured for One-Shot mode without Restart. Also, the Start Delay Control register of the Sequencer driving the output frame buffer would be configured with a start delay to compensate for the pipeline delay introduced by the 2-D Convolver. Finally, the crosspoint switch would be configured in 1:1 mode so that the sequence generator output has a 1 to 1 mapping to the chip output.

For applications requiring decimation of the original image, the Step Size could be increased to provide addressing which skips over pixels along a row. Similary, the Block Step Size could be increased such that pixel rows are skipped.

## FFT Processing

The application shown in Figure 5 depicts the architecture of a simplified radix 2 FFT processor. In this application the Address Sequencer drives a memory bank which feeds the arithmetic processor with data. In a radix 2 implementation, the arithmetic processor takes two complex data inputs and produces two results. These results are then stored in the registers from which the data came. This type of implementation is referred to as an "in place" FFT algorithm.
The arithmetic processing unit performs an operation know as the radix 2 butterfly which is shown graphically in Figure 6. In this diagram the node in the center of the butterify represents summing point while the arrow represents a multiplication point. The flow of an FFT computation is described by diagrams comprised of many butterflies as shown in Figure 7.
The FFT processing shown in Figure 7 consists of three stages of radix 2 butterfly computation. The read/write addressing, expressed in binary, for each stage is shown in Table 5. The specialized addressing required here is produced by using the crosspoint switch to map the address bits from the sequence generator to the chip output.

The mapping for the sequencer's crosspoint switch is determined, by inspecting the addressing for each stage. For example, the first stage of addressing is generated by configuring the crosspoint switch so that bit 0 of the switch input is mapped to bit 2 of the switch output, bit 1 of the
switch input is mapped to bit 0 of the output, and bit 2 of the switch input is mapped to bit 1 of the switch output. The remainder of the switch I/O map is configured 1:1, i.e. bit 3 of the switch input is mapped to bit 3 of the switch output. Under this configuration, a sequence generator output of $0,1,2,3,4,5,6,7$ will produce a crosspoint switch output of $0,4,1,5,2,6,3,7$. The switch maps for the other stages as well as a map for the bit-reverse addressing of the FFT result is given in Table 5.
The serial count required as input for the crosspoint switch is generated by configuring the sequence generator with the following:

| 1. Start Address | $=0$ | 4. Step Size | $=1$ |
| :--- | :--- | :--- | :--- |
| 2. Block Size | $=8$ | 5. Block Step Size | $=0$ |
| 3. Number of Blocks $=1$ |  |  |  |

Under this configuration the sequence generator will produce a count from 0 to 7 in increments of 1 . The FFT length corresponds to the Block Size, in this case 8.
The serial count from the sequence generator is converted into the desired addressing sequence by applying the appropriate map to the crosspoint switch. In this application, the switch mapping changes for each stage of the FFT computation. Thus, while one address sequence is being completed, the crosspoint switch is being configured for the next stage of FFT addressing. When one stage of addressing is complete, the new switch configuration is loaded into the current state registers by an internal or externally generated start or restart.
The crosspoint switch is configured for the first stage of addressing by writing a 0 to switch output register 2, a 2 to switch output register 1, and a 0 to switch output register 2. These values are loaded by first writing the address of switch output register 0 and then loading data using auto-address increment mode (see Table 1). The remaining registers are assumed to be configured in $1: 1$ mode as a result of a prior "RESET". The second and third stages of addressing are generated by reconfiguring the above three registers.
The Address Sequencer can be configured in dual sequencer mode to provide both read and write addressing for each butterfly. Since 2 independent 12 bit sequences can be generated by the Address Sequencer, it can be used to provide read/write addressing for FFT's up to 4096 points. The programmable delay between the MSW and LSW of the Sequencer output is used to compensate for the pipeline delay associated with the arithmetic processor.

TABLE 5. FFT ADDRESSING BY COMPUTATIONAL STAGE

| STAGE 1 <br> R/W ADDR. | STAGE 2 <br> R/W ADDR. | STAGE 3 <br> R/W ADDR. | OUTPUT <br> ADDRESSING |
| :---: | :---: | :---: | :---: |
| 000 | 000 | 000 | 000 |
| 100 | 010 | 001 | 100 |
| 001 | 001 | 010 | 010 |
| 101 | 011 | 011 | 110 |
| 010 | 100 | 100 | 001 |
| 110 | 110 | 101 | 101 |
| 011 | 101 | 110 | 011 |
| 111 | 111 | 111 | 111 |
|  |  |  |  |
| SWITCH MAPPING |  |  |  |
| O21 | 201 | 210 | 012 |



FIGURE 5. FFT PROCESSOR


$$
\begin{aligned}
& N=\text { FFT LENGTH } \\
& w_{N}^{k}=e^{-j \frac{2 \pi K}{N}}
\end{aligned}
$$

FIGURE 6. BUTTERFLY FOR DECIMATION-IN-FREQUENCY


FIGURE 7. COMPLETE EIGHT-POINT IN-PLACE DECIMATION-IN-FREQUENCY FFT

## Absolute Maximum Ratings



```
Input, Output or I/O Voltage Applied . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . GND-0.5V to VCC+0.5V
```




```
0jc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15.1 . . . . . . . . . . . . . . (PLCC), 10.10
0ja ............................................................................................... . 43.10
Gate Count
. . . . . . . . . . . . . . . 8388 Gates
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +1500
```



```
ESD Classification
Class }
CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
```


## Operating Conditions


D.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{JH}}$ | 2.0 | - | V | $V_{C C}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{l}^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $1 \mathrm{OL}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 1/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | ICCsB | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.25 \mathrm{~V}, \text { Outputs open } \end{aligned}$ |
| Operating Power Supply Current | ICCOP | - | 99 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V}, \\ & \text { Outputs Open, (Note 1) } \end{aligned}$ |
| Input Capacitance | $\mathrm{ClN}_{\text {IN }}$ | - | 10 | pF | $f=1 \mathrm{MHz}, \mathrm{~V}_{\mathrm{CC}}=\text { Open }$ |
| Output Capacitance | $\mathrm{Co}_{0}$ | - | 10 | pF | to device GND. (Note 2). |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for ICCOP is $3 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) (Note 2)

| PARAMETER | SYMBOL | -33 (33MHz) |  | -40 (40MHz) |  | -50 (50MHz) |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ | 30 | - | 25 | - | 20 | - | ns |  |
| Clock Pulse Width High | $\mathrm{T}_{\mathrm{CH}}$ | 12 | - | 10 | - | 9 | - | ns |  |
| Clock Pulse Width Low | TCL | 12 | - | 10 | - | 9 | - | ns |  |
| Setup Time DO-6 to WR\# High | TDS | 14 | - | 13 | - | 12 | - | ns |  |
| Hold Time DO-6 from WR \# High | TDH | 0 | - | 0 | - | 0 | - | ns |  |
| Set-up Time AO, CS\#, to WR\# Low | $T_{\text {AS }}$ | 5 | - | 5 | - | 5 | - | ns |  |
| Hold Time AO, CS\#, from WR\# High | $\mathrm{T}_{\text {AH }}$ | 0 | - | 0 | - | 0 | - | ns |  |
| Pulse Width for WR\# Low | TWRL | 13 | - | 12 | - | 10 | - | ns |  |
| Pulse Width for WR\# High | TWRH | 13 | - | 12 | - | 10 | - | ns |  |
| WR\# Cycle Time | TWP | 30 | - | 25 | - | 20 | - | ns |  |
| Set-up Time STARTIN\#, DLYBLK, to Clock High | TIS | 12 | - | 10 | - | 8 | - | ns |  |
| Hold Time STARTIN\#, DLYBLK, to Clock High | $\mathrm{TIH}^{\text {H}}$ | 0 | - | 0 | - | 0 | - | ns |  |
| Clock to Output Prop. <br> Delay on OUTO-23 | $\mathrm{T}_{\text {PDO }}$ | - | 15 | - | 13 | - | 12 | ns |  |
| Clock to Output Prop. Delay on STARTOUT\#, BLKDONE\#, DONE\#, ADDVAL\#, and BUSY\# | TPDS | - | 15 | - | 13 | - | 12 | ns |  |
| Output Enable Time | TEN | - | 20 | - | 15 | - | 13 | ns |  |
| Output Disable Time | $\mathrm{T}_{\mathrm{OD}}$ | - | 20 | - | 15 | - | 13 | ns | Note 1 |
| Output Rise/Fall Time | Torf | - | 5 | - | 3 | - | 3 | ns | Note 1 |
| RST\# Low Time | TRST | 2 Clock Cycles |  |  |  |  |  | ns |  |

NOTES:

1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. A.C. Testing is performed as follows: Input levels (CLK Input) $=4.0 \mathrm{~V}$ and OV; input levels (All other inputs) $=\mathrm{OV}$ and 3.0 V ; Input timing reference levels: $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$; Output timing references: $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
A.C. Test Load Circuit


| OUTPUT PIN | $C_{L}$ |
| :--- | :---: |
| BLOCKDONE\# | 40 pF |
| DONE\# |  |
| ADDVAL\# |  |
| STARTOUT\# |  |
| BUSY\# |  |
| OUTO-23 | 100 pF |

*Test Head Capacitance
Switch S1 Open for ICCSB and ICCOP Tests.

Timing Diagrams


CLOCK AC PARAMETERS


ADDRESS/CHIP SELECT SETUP AND HOLD


INPUT SETUP AND HOLD


OUTPUT ENABLE, DISABLE TIMING


WR\# AC PARAMETERS


OUTPUT PROPOGATION DELAY

HSP45240/883

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Block Oriented 24-Bit Sequencer
- Configurable as Two Independent 12-Blt Sequencers
- $24 \times 24$ Crosspoint Switch
- Programmable Delay on 12 Outputs
- Multi-Chip Synchronization Signals
- Standard $\mu$ P Interface
- 100pF Drive on Outputs
- DC to 40MHz Clock Rate


## Applications

- 1-D, 2-D Filtering
- Pan/Zoom Addressing
- FFT Processing
- Matrix Math Operations


## Description

The Harris HSP45240 is a high speed Address Sequencer which provides specialized addressing for functions like FFTs, 1-D and 2-D filtering, matrix operations, and image manipulation. The sequencer supports block oriented addressing of large data sets up to 24 bits at clock speeds up to 40 MHz .

Specialized addressing requirements are met by using the onboard $24 \times 24$ crosspoint switch. This feature allows the mapping of the 24 address bits at the output of the address generator to the 24 address outputs of the chip. As a result, bit reverse addressing, such as that used in FFTs, is made possible.

A single chip solution to read/write addressing is also made possible by configuring the HSP45240 as two 12-bit sequencers. To compensate for system pipeline delay, a programmable delay is provided on 12 of the address outputs.

The HSP45240 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs, with the exception of clock, are TTL compatible.

## Block Diagram



| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0. 8 V |  |
| Input, Output Voltage Applied | GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range . | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175{ }^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, | $+300^{\circ} \mathrm{C}$ |
| SD Classification | Class |


| Rellabillty Information |  |  |
| :---: | :---: | :---: |
| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| Ceramic PGA Package . | $37.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $10.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125{ }^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package | ......... | . 1.35 Watt |
| Gate Count |  | 8,388 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . +4.5 V to +5.5 V
Operating Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{\text {CC }} \text { or GND } \\ & V_{\text {CC }}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & \mathrm{f}=33 \mathrm{MHz} \\ & \mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 99 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq T \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $3 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq$ $1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested (Note 1)

| PARAMETERS | SYMBOL | CONDITIONS | GROUPA SUBGROUP | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25MHz) |  | -33 (33MHz) |  | -40 (40MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MiN | MAX |  |
| Clock Period | TCP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 30 | - | 25 | - | ns |
| Clock Pulse Width High | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Clock Pulse Width Low | $\mathrm{T}_{\mathrm{CL}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Setup Time D0-6 to WR\# High | TDS |  | 9, 10, 11 | $-55{ }^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 16 | - | 14 | - | ns |
| Hold Time DO-6 from WR\# Low | ${ }^{\text {T }}$ DH |  | 9, 10, 11 | $-55{ }^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125{ }^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Set-up Time A, CS\#, to WR\# Low | $\mathrm{T}_{\text {AS }}$ |  | 9,10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125{ }^{\circ} \mathrm{C}$ | 5 | - | 5 | - | 5 | - | ns |
| Hold Time A,CS\#, from WR\# High | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Pulse Width for WR\# Low | TWRL |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 14 | - | 12 | - | ns |
| Pulse Width for WR\# High | TWRH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 14 | - | 12 | - | ns |
| WR\# Cycle Time | TwP |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 30 | - | 25 | - | ns |
| Set-up Time STARTIN\#, DLYBLK, to to Clock High | TIS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Hold Time STARTIN\#, DLYBLK, to Clock High | $\mathrm{T}_{\mathrm{IH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Clock to Output Prop. Delay on OUTO-23 | TPDO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 18 | - | 16 | - | 14 | ns |
| Clock to Prop. Delay, On STARTOUT\#, BLKDONE\#, DONE\#, ADVAL\#, and BUSY\# | TPDS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 18 | - | 16 | - | 14 | ns |
| Output Enable Time | TEN | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125{ }^{\circ} \mathrm{C}$ | - | 22 | - | 20 | - | 15 | ns |
| RST\# Low Time | TRST |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ |  |  | 2 Cloc | Cycles |  |  | ns |

## NOTES:

1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V , Inputs are driven at 3.0 V for Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $C_{L}=40 \mathrm{pF}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25MHz) |  | -33 (33MHz) |  | -40 (40MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{CIN}_{1}$ | $v_{\mathrm{CC}}=$ Open, $f=1 \mathrm{MHz}$, All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Capacitance | COUT | $V_{C C}=$ Open $f=1 \mathrm{MHz}$, All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Disable Delay | Toez |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125{ }^{\circ} \mathrm{C}$ | - | 22 | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 5 | - | 5 | - | 3 | ns |
| Output Fall Time | Tof |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125{ }^{\circ} \mathrm{C}$ | - | 5 | - | 5 | - | 3 | ns |

NOTES: 1. Parameters listed in Table 3 are controled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 A, 8 B, 10,11$ |
| Group A | - | $1,2,3,7,8 A, 8 B, 9,10,11$ |
| Groups C\&D | Samples $/ 5005$ | $1,7,9$ |

HSP45240/883
Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | PGA PIN | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\left\|\begin{array}{l} \text { PGA } \\ \text { PIN } \end{array}\right\|$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | GND | GND | B9 | OUT14 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | Out8 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K6 | BUSYB | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A3 | OUT23 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C1 | D2 | F10 | G1 | CSB | F5 | K7 | DONEB | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A4 | $\mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ | C2 | D1 | F9 | G2 | AO | F6 | K8 | OUTO | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A5 | OUT20 | $\mathrm{VCC}^{\prime} / 2$ | C10 | GND | GND | G10 | OUT6 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K9 | $V_{C C}$ | $\mathrm{v}_{\mathrm{Cc}}$ |
| A6 | OUT19 | $\mathrm{v}_{\mathrm{cc} / 2}$ | C11 | OUT12 | $\mathrm{V}_{\mathrm{CC}} / 2$ | G11 | OUT7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | OUT3 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| A7 | $\mathrm{v}_{\mathrm{CC}}$ | $v_{C C}$ | D1 | D4 | F12 | H1 | CLK | FO | L2 | OEHB | F13 |
| A8 | OUT16 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D2 | D3 | F11 | H2 | GND | GND | L3 | DLYBLK | F11 |
| A9 | OUT15 | $\mathrm{v}_{\mathrm{CC}} / 2$ | D10 | OUT10 | $\mathrm{v}_{\mathrm{cc} / 2}$ | H10 | OUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L4 | STARTOUTB | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A10 | OUT13 | $\mathrm{v}_{\mathrm{CC} / 2}$ | D11 | OUT11 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H11 | $V_{C C}$ | $V_{C C}$ | L5 | $V_{\text {cc }}$ | $v_{C C}$ |
| B1 | Do | F8 | E1 | D6 | F7 | J1 | RSTB | F14 | L6 | BLOCKDONEB | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B3 | OUT22 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E2 | D5 | F13 | J2 | $V_{C C}$ | $V_{C C}$ | L7 | GND | GND |
| B4 | OUT21 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E10 | OUT9 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J10 | GND | GND | L8 | OUT1 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B5 | GND | GND | E11 | $\mathrm{v}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | J11 | OUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L9 | OUT2 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| B6 | OUT18 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F1 | WRB | F4 | K3 | OELB | F12 |  |  |  |
| B7 | OUT17 | $\mathrm{v}_{\mathrm{CC}} / 2$ | F2 | GND | GND | K4 | STARTINB | F6 |  |  |  |
| B8 | GND | GND | F10 | GND | GND | K5 | ADVALB | $\mathrm{VCC} / 2$ |  |  |  |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(\mathbf{2 . 7 V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $V_{C C}$ and $G N D$ per position.
5. $F 0=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2,40 \%-$ 60\% Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \max ., \mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Metallization Topology

DIE DIMENSIONS:
$186 \times 222 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY:
$1.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout


## Features

- Reconfigurable 256 Stage Binary Correlator
- 1-Bit Reference $\times$ 1, 2, 4, or 8-Bit Data
- Separate Control and Reference Interfaces
- 25.6, 33MHz Versions
- Configurable for 1-D and 2-D Operation
- Double Buffered Mask and Reference
- Programmable Output Delay
- Cascadable
- Standard Microprocessor Interface


## Applications

- Radar/Sonar
- Spread Spectrum Communications
- Pattern/Character Recognition
- Error Correction Coding


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP45256JC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP45256JC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 84 Lead PLCC |
| HSP45256GC-25 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP45256GC-33 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The Harris HSP45256 is a high-speed, 256 tap binary correlator. It can be configured to perform one- or twodimensional correlations of selectable data precision and length. Multiple HSP45256's can be cascaded for increased correlation length. Unused taps can be masked out for reduced correlation length.

The correlation array consists of eight 32 -tap stages. These may be cascaded internally to compare 1,2,4 or 8-bit input data with a 1 -bit reference. Depending on the number of bits in the input data, the length of the correlation can be up to 256, 128, 64, or 32 taps. The HSP45256 can also be configured as two separate correlators with window sizes from 4 by 32 to 1 by 128 each. The mask register can be used to prevent any subset of the 256 bits from contributing to the correlation score.

The output of the correlation array (correlation score) feeds the weight and sum logic, which gives added flexibility to the data format. In addition, an offset register is provided so that a preprogrammed value can be added to the correlation score. This result is then passed through a user programmable delay stage to the cascade summer. The delay stage simplifies the cascading of multiple correlators by compensating for the latency of previous correlators.

The Binary Correlator is configured by writing a set of control registers via a standard microprocessor interface. To simplify operation, both the control and reference registers are double buffered. This allows the user to load new mask and reference data while the current correlation is in progress.

Block Diagram


Pinouts



Pin Description

| SYMBOL | PLCC PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | 16, 33, 63 |  | The +5 V power supply pin. |
| GND | 14, 35, 55, 70, 77 |  | Ground. |
| DINO-7 | 17-24 | 1 | The DINO-7 bus consists of eight single data input pins. The assignment of the active pins is determined by the configuration. Data is loaded synchronous to the rising edge of CLK. DINO is the LSB. |
| DOUT0-7 | 60-62, 64-68 | 0 | The DOUT0-7 bus is the data output of the correlation array. The format of the output is dependent on the window configuration and bit weighting. DOUTO is the LSB. |
| CLK | 15 | 1 | System clock. Positive edge triggered. |
| CASINO-12 | 1-13 | 1 | CASINO-12 allows multiple correlators to be cascaded by connecting CASOUTO-12 of one correlator to CASINO-12 of another. The CASIN bus is added internally to the correlation score to form CASOUT. CASINO is the LSB. |
| CASOUTO-12 | 69, 71-76, 78-83 | 0 | CASOUT0-12 is the output correlation score. This value is the delayed sum of all the 256 taps of one chip and CASINO-12. When the part is configured to act as two independent correlators, CASOUT0-8 represents the correlation score for the first correlator while the second correlation score is available on the AUXOUT0-8 bus. In this configuration, the cascading feature is no longer an option. CASOUTO is the LSB. |
| OEC\# | 84 | 1 | OEC\# is the output enable for CASOUT0-12. When OEC\# is high, the output is threestated. Processing is not interrupted by this pin. (Active low.) |
| TXFR\# | 36 | 1 | TXFR\# is a synchronous clock enable signal that allows the loading of the reference and mask inputs from the preload register to the correlation array. Data is transferred on the rising edge of CLK while TXFR\# is low. (Active low.) |
| DREF0-7 | 25-32 | 1 | DREF0-7 is an 8-bit wide data reference input. This is the input data bus used to load the reference data. RLOAD\# going active initiates the loading of the reference registers. This input bus is used to load the reference registers of the correlation array. The manner in which the reference data is loaded is determined by the window configuration. If the window configuration is $1 \times 256$, the reference bits are loaded one at a time over DREF7. When the HSP45256 is configured as an $8 \times 32$ array, the data is loaded into all stages in parallel. In this case, DREF7 is the reference data for the first stage and DREFO is the reference data for the eighth stage. The contents of the reference data registers are not affected by changing the window configuration. DREFO is the LSB. |
| RLOAD\# | 34 | 1 | RLOAD\# enables loading of the reference registers. Data on DREF0-7 is loaded into the preload registers on the rising edge of RLOAD\#. This data is transferred into the correlation array by TXFR\#. (Active low.) |
| DCONTO-7 | 41-48 | I | DCONTO-7 is the control data input, which is used to load the mask bit for each tap as well as the configuration registers. The mask data is sequentially loaded into the eight stages in the same manner as the reference data. DCONT0 is the LSB. |
| CLOAD\# | 37 | 1 | CLOAD\# enables the loading of the data on DCONT0-7. The destination of this data is controlled by AO-2. (Active low.) |
| A0-2 | 38-40 | 1 | A0-2 is a 3-bit address that determines what function will be performed when CLOAD\# is active. This address bus is set up with respect to the rising edge of the load signal, CLOAD\#. AO is the LSB. |
| AUXOUT0-8 | 50-54, 56-59 | 0 | AUXOUT0-8 is a 9-bit bus that provides either the data reference output or the 9 -bit correlation score of the second correlator, depending on the configuration. When the user programs the chip to be two separate correlators, the score of the second correlator is output on this bus. When the user has programmed the chip to be one correlator, AUXOUTO-7 represents the reference data out, with the state of AUXOUT0-8 undefined. AUXOUTO is the LSB. |
| OEA\# | 49 | I | The OEA\# signal is the output enable for the AUXOUTO-8 output. When OEA\# is high, the output is disabled. Processing is not interrupted by this pin. (Active low.) |

## Functional Description

The correlation array consists of eight 32-bit stages. The first stage receives data directly from input pin DIN7. The other seven stages receive input data from either an external data pin, DINO-6, or from the shift register output of the previous stage, as determined by the Configuration Register. When the part is configured as a single correlator the sum of correlation score, offset register and cascade input appears on CASOUTO-12. Delayed versions of the data and reference inputs appear on DOUTO-7 and AUXOUTO-7, respectively. The input and output multiplexers of the correlation array are controlled together; for example, in a $1 \times 256$ correlation, the input data is loaded into DIN7 and the output appears on DOUT7. The configuration of the data bits, the length of the correlation (and in the two- dimensional data, the number of rows), is commonly called the correlation window.

## Correlator Array

The core of the HSP45256 is the correlation array, which consists of eight 32-tap stages. A single correlator cell consists of an XNOR gate for the individual bit comparison; i.e., if the data and reference bits are either both high or both low, the output of the correlator cell is high. In addition, two latches, one for the reference and one for the control data path are contained in this cell. These latches are loaded from the preload registers on the rising edge of CLK when TXFR\# is low so that the reference and mask values are updated without interrupting data processing.
The mask function is implemented with an AND gate. When a mask bit is a logic low, the corresponding correlator cell output is low.
The function performed by one correlation cell is:

$$
\left(D_{i, n} X N O R R_{i, n}\right) \text { AND } M_{i, n}
$$

where:

$$
\begin{aligned}
& D_{i, n}=\text { Bit } i \text { of data register } n \\
& R_{i, n}=\text { Bit } i \text { of reference register } n \\
& M_{i, n}=\text { Bit } i \text { of mask register } n
\end{aligned}
$$

The reference and mask bits are loaded sequentially, N bits at a time, where N depends on the current configuration (See Table 3). New reference data is loaded on the rising edge of RLOAD\# and new mask data is loaded on the rising edge of CLOAD\#. The mask and reference bits are stored internally in shift registers, so that the mask and reference information that was loaded most recently will be used to process the newest data. When new information is loaded in, the previous contents of the mask and reference bits are shifted over by one sample, and the oldest information is lost. There are no registers in the multiplexer array (Figure 1), so the data on DOUTO-7 corresponds to the date in the last element of the correlation array. When monitoring DOUT0-7, AUXOUT0-8, and REFOUT0-7, only those bits listed in Table 3 are valid.

## Weight and Sum Logic

The Weight and Sum Logic provides the bit weighting and final correlator score from the eight stages of the correlation array. For a $1 \times 256$ 1-D configuration, the outputs of each of the stages are given a weight of 1 and then added together. In a $8 \times 32$ (8-bit data) configuration, the output of each stage will be shifted so that the output data represents an 8 -bit word, with stage seven being the MSB.
The 13-bit offset register is loaded from the control data bus. Its output is added to the correlation score obtained from the correlator array. This sum then goes to the programmable delay register data input.
When the chip is configured as dual correlators, the user has the capability of loading two different offset values for the two correlators.
The Programmable Delay Register sets the number of pipeline stages between the output of the weight and sum logic and the input of the Cascade Summer. This delay register is used to align the output of multiple correlators in cascaded configurations (See Applications). The number of delays is programmable from 1 to 16, allowing for up to 16 correlators to be cascaded. When the HSP45256 is configured as dual correlators, the delay must be set to 0000, which specifies a delay of 1.

## Cascade Summer

This is used for cascading several correlators together. This value on this bus represents the correlation score from the previous HSP45256 that will be summed with the current score to provide the final correlation score. When several correlators are cascaded, the CASOUTO-12 of each of the other correlators is connected to the CASINO-12 of the next correlator in the chain. The CASINO-12 of the first chip is tied low. The following function represents the correlation score seen on CASOUTO-12 of each correlator:

$$
\begin{aligned}
\text { CASOUT }(\mathrm{n})= & (\text { W7 } \times \text { CO7) }(\mathrm{n} \text {-Delay })+(\text { W6 } \times \text { CO6) }(\mathrm{n} \text {-Delay })+ \\
& (\text { W5 } \times \text { CO5) }(\mathrm{n} \text {-Delay })+(\text { W } 4 \times \text { CO4) } \mathrm{n} \text {-Delay })+ \\
& (\text { W3 } \times \text { CO3) }(\mathrm{n} \text {-Delay })+(\text { W } 2 \times \text { CO2) }(\mathrm{n} \text {-Delay })+ \\
& \text { (W1 } \times \text { CO1)(n-Delay })+(\text { W0 } \times \text { COO) }(\mathrm{n} \text {-Delay })+ \\
& \text { Offset }(n \text {-Delay })+\text { CASIN. }
\end{aligned}
$$

where:
CO0-CO7 are the correlation score outputs out of the correlation stages; WO-W7 is the weight given to each stage; n -Delay represents the delay on the weighted and summed correlation score through the Programmable Delay Register; Offset is the value programmed into the Offset register; CASIN is the cascade input.


## Control Registers

The 3-bit address value, AO-2, is used to determine which internal register will be loaded with the data on DCONT0-7. The function is initiated when CLOAD\# is brought low, and the register is loaded on the rising edge of CLOAD\#. Table 1 indicates the function associated with each address. Table 2 shows the function of the bits in each of the registers.

TABLE 1. ADDRESS MAPPING

| A2 | A1 | A0 | DESTINATION |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Mask Register |
| 0 | 0 | 1 | Configuration Register |
| 0 | 1 | 0 | Offset Register A-Most Significant Bits |
| 0 | 1 | 1 | Offset Register A-Least Significant Bits |
| 1 | 0 | 0 | Programmable Delay Register |
| 1 | 0 | 1 | Offset Register B-Most Significant Bits |
| 1 | 1 | 0 | Offset Register B-Least Significant Bits |
| 1 | 1 | 1 | Reserved |

TABLE 2. CONTROL REGISTER BITS

## A0-2 $=000$ Mask Register

| MR7 | MR6 | MR5 | MR4 | MR3 | MR2 | MR1 | MR0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

MR0-7: Mask Register. When mask register bit $\mathrm{N}=1$, the corresponding reference register bit is enabled. Mask register data is loaded from the DCONT0-7 bus into a holding register on the rising edge of CLOAD\# and is written to the mask register on the rising edge of TXFR".

## A0-2 $=001$ Configuration Reglster

| - | - | TC | CONFIG4 | CONFIG3 | CONFIG2 | CONFIG1 | CONFIG0 |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- |

TC: Configures correlator for two's complement input. Inverts the MSB of the input data, where the position of the MSB depends on the current configuration.
CONFIG4: The state of CONFIG4 sets up the HSP45256 as either one or two correlators. When CONFIG4 $=0$, the HSP45256 is configured. as one correlator with the correlation score available on CASOUTO-12. When CONFIG4 $=1$, the HSP45256 is configured as dual correlators with the first correlator's score available on CASOUTO-8 and the second score available on AUXOUTO-8. When the chip is configured as dual correlators, the Programmable Delay must be set to 0000 for a delay of 1.
CONFIG2-3: Control the number of data bits to be correlated. See Table 3.
CONFIG0-1: CONFIG1 and CONFIG0 represent the length of the correlation window as indicated in Table 3.

## A0-2 $=010$ MS Offset Register A

| $\cdot$ | - | - | OFFA12 | OFFA11 | OFFA10 | OFFA9 | OFFA8 |
| :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |

OFFA8-12: Most significant bits of Offset Register A. This is the register used in single correlator mode.
A0-2 = 011 LS Offset Register A

| OFFA7 | OFFA6 | OFFA5 | OFFA4 | OFFA3 | OFFA2 | OFFA1 | OFFA0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

OFFA0-7: Least significant bits of Offset Register A.
A0-2 $=100$ Programmable Delay

| $\cdot$ | $\cdot$ | - | - | PDELAY3 | PDELAY2 | PDELAY1 | PDELAYO |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- |

PDELAYO-3: Controls amount of delay from the weight and sum logic to the cascade summer. The number of delays is 1-16, with PDELAY $=0000$ corresponding to a delay of 1 and PDELAY = 1111 corresponding to a delay of 16 .

## AO-2 $=101$ MS Offset Register B



OFFB8: Most significant bit of Offset Register B. In dual correlator mode, this register is used for the correlator whose output appears on the AUXOUT pins.

A0-2 $=110$ LS Offset Register B

| OFFB7 | OFFB6 | OFFB5 | OFFB4 | OFFB3 | OFFB2 | OFFB1 | OFFB0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

[^6]| CONFIGURATION |  |  |  |  | NO. OF CORRELATORS | DATA BITS | ROWS | LENGTH | CORRELATOR | ACTIVE INPUTS |  | ACTIVE OUTPUTS |  |  | OUTPUT WEIGRTING |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4 | 3 | 2 | 1 | 0 |  |  |  |  |  | DIN | DREF | DOUT | AUXOUT | CASOUT | C07 | CO6 | CO5 | CO4 | CO3 | CO2 | CO1 | COO |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 256 | - | 7 | 7 | 7 | 7 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 2 | 128 | - | 7, 3 | 7,3 | 7, 3 | 7, 3 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 4 | 64 | - | 7, 5, 3, 1 | 7, 5, 3, 1 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 | 32 | - | 7-0 | 7-0 | 7-0 | 7-0 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 0 | 1 | 1 | 2 | 1 | 128 | - | 7, 3 | 7 | 7, 3 | 7,3 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 1 | 0 | 1 | 2 | 2 | 64 | - | 7, 5, 3, 1 | 7,5 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 1 | 1 | 1 | 2 | 4 | 32 | - | 7-0 | 7,6, 5, 4 | 7-0 | 7-0 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 0 | 1 | 4 | 1 | 64 | - | 7, 5, 3, 1 | 7 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 8 | 8 | 2 | 2 | 4 | 4 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 4 | 2 | 32 | - | 7-0 | 7,6 | 7-0 | 7-0 | 12-0 | 8 | 8 | 2 | 2 | 4 | 4 | 1 | 1 |
| 0 | 1 | 1 | 1 | 1 | 1 | 8 | 1 | 32 | - | 7-0 | 7 | 7-0 | 7-0 | 12.0 | 128 | 8 | 32 | 4 | 64 | 2 | 16 | 1 |
| 1 | 0 | 0 | 0 | 1 | 2 | 1 | 1 | 128 | A | 7 3 | 7 3 | 7 3 | 8-0 | 12-0 | 1 | 1 | 1 | 1 | 1 | $1$ | 1 | 1 |
| 1 | 0 | 0 | 1 | 0 | 2 | 1 | 2 | 64 | $\begin{aligned} & \mathbf{A} \\ & \mathbf{R} \end{aligned}$ | $\begin{array}{r} 7,5 \\ 3,1 \end{array}$ | $\begin{aligned} & 7,5 \\ & 3,1 \end{aligned}$ | $\begin{array}{r} 7,5 \\ 3,1 \end{array}$ | 8-0 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 | 2 | 1 | 4 | 32 | A | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 7-4 | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 8-0 | 12-0 | 1 | 1 | 1 | 1 | $i$ | 1 | $\stackrel{\square}{1}$ | $\stackrel{\square}{1}$ |
| 1 | 0 | 1 | 1 | 0 | 2 | 2 | 1 | 64 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{aligned} & 7,5 \\ & 3,1 \end{aligned}$ | 7 3 | $\begin{array}{r} 7,5 \\ 3,1 \end{array}$ | $8-0$ | 12.0 | 2 | 2 | 1 | 1 | 2 | 2 | 1 | 1 |
| 1 | 0 | 1 | 1 | 1 | 2 | 2 | 2 | 32 | A | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 7,6 3,2 | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 8-0 | 12-0 | 2 | 2 | 1 | 1 | 2 | 2 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 | 2 | 4 | 1 | 32 | A | 7-4 $3-0$ | 7 3 | $7-4$ $3-0$ | 8-0 | $12-0$ - | 8 | 2 | 4 | 1 | 8 | 2 | 4 | 1 |

During reference register loading, the 8-bits, DREF0-7 are used as reference data inputs. The falling edge of RLOAD\# initiates reference data loading; when RLOAD\# returns high, the data on DREF0-7 is latched into the selected correlation stages. The active bits on DREF0-7 are controlled by the current configuration.

The window configuration is determined by the state of control signals upon programming the control register. Table 3 represents the programming information required for each window configuration. In Table 3, note that the data listed for Output Weighting refers to the weights given to each of the Correlation Sum Outputs (CO0-7 in Figure 1).
During initialization, the loading configuration for the reference data is set by the user. Table 3 shows the loading options. These load controls specify whether the reference data for a given stage comes from the shift register output of the previous stage or from an external data pin.

## Applications

## Single HSP45256-1-Bit Data, 256 Samples

A $1 \times 256$ (1-D configuration) correlation requires only 1 HSP45256. To initialize the correlator, all the reference bits, control bits, the delay value of the variable delay, and the window configuration must be specified.

TABLE 4. REGISTER CONTENTS FOR $1 \times 256$ CORRELATOR WITH EQUAL WEIGHTING

| A0-2 | DCONT0-7 | NOTES |
| :---: | :---: | :--- |
| 001 | 00000000 | $1256-$-tap correlator: $1 \times 256$ window <br> configuration, reference loaded from <br> DREF7, eight stages weighted equally, <br> DIN 7 and DOUT7 are the data input <br> and output, respectively. |
| 010 | 00000000 | Offset Register $A=0$ |
| 011 | 00000000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register $B=0$ (Loading of this <br> register optional in this mode.) |
| 110 | 00000000 |  |

The loading of the reference and mask registers may be done simultaneously by setting $\mathrm{AO}-2=000$, setting the DREF and DCONT inputs to their proper values and pulsing RLOAD\# and CLOAD\# low. In this configuration, DREF7 loads the reference data and DCONT7 loads the mask information; both sets of data are loaded serially. It will take 256 load pulses (RLOAD\#) to load the reference array, and 256 CLOAD\# pulses to load the mask array. Upon completion of the mask and register loading, TXFR\# is pulsed low. which iransiers the reterence and control data from the preload registers to the reference and mask registers, updating the data that will be used in the correlation. Reference and mask data can be loaded more quickly by configuring the correlator as an 8 row by 32 sample array, loading the bits eight at a time, then changing the configuration back to $1 \times 256$ to perform the correlation.

## Single HSP45256 - 8-Bit Data, 32 Samples

An $8 \times 32$ correlation also requires only 1 HSP45256. To initialize the correlator, all the reference bits, control bits, the value of the programmable delay, and the window configuration must be specified.

Again, the loading of the reference and mask registers can be done simultaneously. Due to the programming initialization, DREF0-7 are used to load the reference data 8-bits at a time. It will take 32 load pulses each of RLOAD\# and CLOAD\# to load both arrays. Upon completion of the mask and register loading, TXFR\# is pulsed low, which transfers the reference and control data from the preload registers to the registers that store the active data.

## TABLE 5. REGISTER LOADING FOR 8 X 32 CORRELATOR

 WITH BINARY WEIGHTING| A0-2 | DCONTO-7 | NOTES |
| :---: | :---: | :--- |
| 001 | 00001111 | 1256 -tap correlator; $8 \times 32$ window configu- <br> ration, 8-bit data stream; reference register <br> is loaded from DREF7 for all stages. Corre- <br> lator score $=(128 \times$ CO7 $)+(64 \times$ CO3 $)+(32$ <br> $\times$ CO5 $)+(16 \times$ CO1 $)+(8 \times$ CO6 $)+(4 \times$ CO4 $)$ <br> $+(2 \times$ CO2 $)+$ COO |
| 010 | 00000000 | Offset Register A $=0000000010000$ |
| 011 | 00010000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register $B=0$ (Loading optional in <br> this mode.) |
| 110 | 00000000 |  |

This configuration performs correlation of an 8 -bit number with a 1-bit reference. Each byte out of the correlation array gives an 8-bit level of confidence that the data corresponds to the reference. The correlation score is the sum of these confidence levels.

## Single HSP45256 - Dual Correlators, 2-Bit Data, 64 Samples

Dual $2 \times 64$ correlators require only one HSP45256. To initialize the correlator, all the reference bits, control bits, the delay value of the variable delay, and the window configuration must be specified.

In this example, each of the dual correlators compares 2-bit data to a 1-bit reference. It will take 64 load pulses (RLOAD\#/CLOAD\#) to completely load the reference and mask registers in the array. The programmable delay must be set to 0 for the output of the two correlators to be aligned.

HSP45256

TABLE 6. REGISTER LOADING FOR DUAL $2 \times 64$ CORRELATORS WITH EQUAL WEIGHTING

| AO-2 | DCONT0-7 | NOTES |
| :---: | :---: | :---: |
| 001 | 00010010 | Dual correlators: each 2 bit data, 64 taps; reference register for correlation A is loaded from DREF7 and DREF5, the reference register for correlator $B$ is loaded from DREF3 and DREF1. Correlator \#1 $=2 \times \mathrm{C07}+2 \times \mathrm{CO} 6+\mathrm{CO} 5+$ CO4, correlator \#2 $=2 \times \mathrm{CO} 3+2 \times \mathrm{CO} 2$ $+\mathrm{CO} 1+\mathrm{CO}$. |
| 010 | 00000000 | Offset Register A $=0000000010000$ |
| 011 | 00010000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register B $=0$ |
| 110 | 00000000 |  |

## Cascading Correlators

Correlators can be cascaded in either a serial or parallel fashion. Longer correlations can be achieved by connecting several correlators together as shown in Figure 2. Each correlator is in a one data bit, one row, 256 tap configuration. The number of bits of significance at the CASOUT output of each correlator builds up from one correlation to the next,
that is, the maximum score out of the first correlator is 256 , the maximum output of the second correlator is 512, etc. In this configuration, the maximum length of the correlation is 4096. This would be implemented with 16 HSP45256's. The programmable delay register in the first correlator would be set for one delay, the second would be set for two, and so on, with the final HSP45256 being set for a delay of 16.
Correlations of more bits can be calculated by connecting CASOUT of each chip to the CASIN of the following chip (Figure 3). The data on the CASOUT lines accumulates in a similar manner as in the $1 \times 256$ mode, except that the maximum output of the first correlator is decimal 960, (hexadecimal 3C0); in the general case, the maximum number of correlators that can be cascaded in this manner is eight, since the maximum output of the last one would be 1E00, which nearly uses up the 13 -bit range of the cascade summer. More parts could be cascaded together if some bits are to be masked out or if the user has a prior knowledge of the maximum value of the correlation score. As before, the delay in the first correlator would be set to one, the second correlator would be set for a delay of two, and so on.

Multiple HSP45256's can be cascaded for two dimensional one bit data (Figure 4). The maximum output for each chip is the same as in the $1 \times 256$ case; the only difference is in the manner in which the correlators are connected. The programmable delay registers would be set as before.

FIGURE 2. 1 BIT, 1024 SAMPLE CONFIGURATION


FIGURE 3. 4 BIT, 256 SAMPLE CONFIGURATION


FIGURE 4. 1 BIT, $32 \times 32$ WINDOW CONFIGURATION

## Reloading Data During Operation

RLOAD\# and CLOAD\# are asynchronous signals that are designed to be driven by the memory interface signals of a microprocessor. TXFR\# is synchronized to CLK so that the mask or reference data is updated on a specific clock cycle. In the normal mode of operation, the user loads the reference and mask memories, then pulses TXFR\# to use that data. The correlator uses the new mask or reference information immediately. Loading of the reference and mask data remains asynchronous as long as there is at least one cycle of CLK between the rising edge of RLOAD\# or CLOAD\# and the TXFR\# pulse.
If the system timing makes it necessary for TXFR\# and RLOAD\# and/or CLOAD\# to be active during the same clock cycle, then they must be treated as synchronous signals; the timing for this case is shown in Figure 5 and given in the AC Timing Specifications ( $T_{T H C L}$ and $T_{C L L H}$ ). In this example, data is loaded during clock cycle 1 and transferred on the rising edge of CLK that occurs in clock cycle two. Another set of data is loaded during clock cycle 2, which will be transferred by a later TXFR\# pulse. The sequence of events is as follows:

1. In clock cycle 1, TXFR\# becomes active at least $T_{\text {TH }}$ nanoseconds after the rising edge of CLK.
2. RLOAD and/or CLOAD\# pulses low; the timing is not critical as long as its rising edge occurs before the end of clock cycle 1. If this condition is not met, it is undetermined whether the data loaded by this pulse will be transferred by the current TXFR\# pulse.
3. The rising edge of TXFR\# occurs while CLK is high during clock cycle 2. The margin between the rising edge of TXFR\# and the falling edge of CLK is defined by TTHCL.
4. RLOAD\# and/or CLOAD\# pulses low. The rising edge of RLOAD\# and CLOAD\# must occur after the falling edge of CLK. The margin between the two is defined by $T_{\text {CLLH }}$.

The time from the rising edge of TXFR\# to the falling edge of CLK must be greater than $T_{T H C L}$, and the time from the falling edge of CLK to the rising edge of RLOAD\# or CLOAD\# must be greater than $T_{\mathbf{s}}$. If this timing is violated, the data being transferred by the TXFR\# pulse shown may or may not include the data loaded in clock cycle 2.


FIGURE 5. LOADING AND TRANSFERRING DATA DURING THE SAME CLOCK CYCLE

## Absolute Maximum Ratings

| Supply Voltage | +8.0V | Thermal Resistance | $\theta_{\text {JA }}$ | $\theta_{\mathrm{Jc}}$ |
| :---: | :---: | :---: | :---: | :---: |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ | PLCC Package | $34^{\circ} \mathrm{C} M$ | $11.3^{\circ} \mathrm{C} / \mathrm{W}$ |
| Storage Temperature Range | . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | PGA Package | $36^{\circ} \mathrm{CN}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
| Junction Temperature. . . . . . . . | $+150^{\circ} \mathrm{C}$ (PLCC),$+175^{\circ} \mathrm{C}$ (PGA) | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ | PLCC Package |  | 2.2W |
| ESD Classification | . Class 1 | PGA Package |  | 2.9W |
|  |  | Gate Count |  | 00 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions



## DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\mathrm{IHC}}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\mathrm{ILC}}$ | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | $\mathrm{I}_{\mathrm{I}}$ | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output Leakage Current | $\mathrm{I}_{\mathrm{O}}$ | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $\mathrm{I}_{\mathrm{CCSB}}$ | - | 500 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{NOte} 3$ |
| Operating Power Supply Current | $\mathrm{I}_{\mathrm{CCOP}}$ | - | 179 | mA | $\mathrm{f}=25.6 \mathrm{MHz}, \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}$ <br> Note <br> N |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 10 | pF | Frequency $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open <br> All measurements are referenced to device ground. |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for ICCOP is $7 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
3. Output load per test load circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

AC Electrical Specifications $\quad\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 1)

| PARAMETER | SYMBOL | 33MHz |  | 25.6MHz |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ | 30 | - | 39 | - | ns |  |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 12 | - | 15 | - | ns |  |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 12 | - | 15 | - | ns |  |
| Set-Up Time DIN to CLK High | $\mathrm{T}_{\mathrm{DS}}$ | 12 | - | 13 | - | ns |  |
| Hold Time CLK High to DIN | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | 0 | - | ns |  |
| TXFR\# Set-Up Time | $\mathrm{T}_{\text {TS }}$ | 12 | - | 13 | - | ns |  |
| TXFR\# Hold Time | $\mathrm{T}_{\text {TH }}$ | 0 | - | 0 | - | ns |  |
| Output Delay DOUT, AUXOUT, CASOUT | $\mathrm{T}_{\mathrm{DO}}$ | - | 15 | - | 20 | ns |  |
| CLOAD\# Cycle Time | $\mathrm{T}_{\text {CLC }}$ | 30 | - | 39 | - | ns |  |
| CLOAD\# High | $\mathrm{T}_{\text {CLH }}$ | 12 | - | 15 | - | ns |  |
| CLOAD\# Low | $\mathrm{T}_{\text {CLL }}$ | 12 | - | 15 | - | ns |  |
| Set-Up Time, A to RLOAD\#, CLOAD\# | $\mathrm{T}_{\text {AS }}$ | 12 | - | 13 | - | ns |  |
| Hold Time, RLOAD\#, CLOAD\# to A | $\mathrm{T}_{\text {AH }}$ | 0 | - | 0 | - | ns |  |
| RLOAD\# Cycle Time | $\mathrm{T}_{\text {RLC }}$ | 30 | - | 39 | - | ns |  |
| RLOAD\# High | $\mathrm{T}_{\text {RLH }}$ | 12 | - | 15 | - | ns |  |
| RLOAD\# Low | $\mathrm{T}_{\mathrm{RLL}}$ | 12 | - | 15 | - | ns |  |
| Set-Up Time, DCONT to CLOAD\# | $\mathrm{T}_{\mathrm{DCS}}$ | 12 | - | 13 | - | ns |  |
| Hold Time, CLOAD\# to DCONT | $\mathrm{T}_{\mathrm{DCH}}$ | 0 | - | 0 | - | ns |  |
| Set-Up Time, DREF to RLOAD\# | $\mathrm{T}_{\text {RS }}$ | 12 | - | 13 | - | ns |  |
| Hold Time, RLOAD\# to DREF | $\mathrm{T}_{\text {RH }}$ | 0 | - | 0 | - | ns |  |
| Output Enable Time | $\mathrm{T}_{\text {OE }}$ | - | 15 | - | 15 | ns |  |
| Output Disable Time | $\mathrm{T}_{\mathrm{OD}}$ | - | 15 | - | 15 | ns | Note 2 |
| Output Rise, Fall Time | $\mathrm{T}_{\text {RF }}$ | - | 6 |  | 6 | ns | Note 2 |
| TXFR\# High to CLK Low | $\mathrm{T}_{\text {THCL }}$ | 3 | - | 3 | - | ns | Note 2 |
| CLK Low to RLOAD\#, CLOAD\# High | $\mathrm{T}_{\text {CLLLH }}$ | 1 | - | 1 | - | ns | Note 2 |

NOTES:

1. AC testing is performed as follows: Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 0 V and 3.0 V ; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}}>1.5 \mathrm{~V}$ and $V_{\mathrm{OL}}<1.5 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
Test Load Circuit


SWITCH S1 OPEN FOR Iccse AND Iccop TEST

## Timing Waveforms



TRANSFER, LOAD TIMING WHEN BOTH OCCUR ON A SINGLE CYCLE

HARRIS
SEMICONDUCTOR

## Features

- This Circuit is Processed in Accordance to MIL-STD883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Reconfigurable 256 Stage Binary Correlator
- 1-Bit Reference $\times \mathbf{1 , 2 , 4 ,}$ or 8-Bit Data
- Separate Control and Reference Interfaces
- Configurable for 1-D and 2-D Operation
- Double Buffered Mask and Reference
- Programmable Output Delay
- Cascadable
- Standard Microprocessor Interface


## Applications

- Radar/Sonar
- Spread Spectrum Communications
- Pattern/Character Recognition
- Error Correction Coding


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :---: | :---: | :---: |
| HSP45256GM-20/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |
| HSP45256GM-25/883 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 85 Lead PGA |

## Description

The Harris HSP45256 is a high-speed, 256 tap binary correlator. It can be configured to perform one- or twodimensional correlations of selectable data precision and length. Multiple HSP45256's can be cascaded for increased correlation length. Unused taps can be masked out for reduced correlation length.
The correlation array consists of eight 32-tap stages. These may be cascaded internally to compare 1, 2, 4 or 8-bit input data with a 1-bit reference. Depending on the number of bits in the input data, the length of the correlation can be up to 256, 128, 64, or 32 taps. The HSP45256 can also be configured as two separate correlators with window sizes from 4 by 32 to 1 by 128 each. The mask register can be used to prevent any subset of the 256 bits from contributing to the correlation score.

The output of the correlation array (correlation score) feeds the weight and sum logic, which gives added flexibility to the data format. In addition, an offset register is provided so that a preprogrammed value can be added to the correlation score. This result is then passed through a user programmable delay stage to the cascade summer. The delay stage simplifies the cascading of multiple correlators by compensating for the latency of previous correlators.

The Binary Correlator is configured by writing a set of control registers via a standard microprocessor interface. To simplify operation, both the control and reference registers are double buffered. This allows the user to load new mask and reference data while the current correlation is in progress.

## Block Diagram



## Pinouts



Pin Description

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | D2, G9, K2 |  | The +5V power supply pin |
| GND | $\begin{aligned} & \text { A10, B1, D10, } \\ & \text { J10, L2 } \end{aligned}$ |  | Ground. |
| DINO-7 | $\begin{aligned} & \text { D1, E1-E3, F2, } \\ & \text { F3, G1, G3 } \end{aligned}$ | I | The DINO-7 bus consists of eight single data input pins. The assignment of the active pins is determined by the configuration. Data is loaded synchronous to the rising edge of CLK. DINO is the LSB. |
| DOUTO-7 | $\begin{aligned} & \text { E9-E11, F9-F11, } \\ & \text { G10, G11 } \end{aligned}$ | 0 | The DOUT0-7 bus is the data output of the correlation array. The format of the output is dependent on the window configuration and bit weighting. DOUTO is the LSB. |
| CLK | C1 | 1 | System clock. Positive edge triggered. |
| CASINO-12 | $\begin{aligned} & \text { A1-A6, B2-B5, } \\ & \text { C2, C5, C6 } \end{aligned}$ | I | CASINO-12 allows multiple correlators to be cascaded by connecting CASOUTO-12 of one correlator to CASINO-12 of another. The CASIN bus is added internally to the correlation score to form CASOUT. CASINO is the LSB. |
| CASOUT0-12 | $\begin{aligned} & \text { A7-A9, A11, } \\ & \text { B6-B11, C10, } \\ & \text { C11, D11 } \end{aligned}$ | 0 | CASOUTO-12 is the output correlation score. This value is the delayed sum of all the 256 taps of one chip and CASINO-12. When the part is configured to act as two independent correlators, CASOUTO-8 represents the correlation score for the first correlator while the second correlation score is available on the AUXOUT0-8 bus. In this configuration, the cascading feature is no longer an option. CASOUT0 is the LSB. |
| OEC\# | C7 | 1 | OEC\# is the output enable for CASOUT0-12. When OEC\# is high, the output is threestated. Processing is not interrupted by this pin. (Active low.) |
| TXFR\# | L3 | I | TXFR\# is a synchronous clock enable signal that allows the loading of the reference and mask inputs from the preload register to the correlation array. Data is transferred on the rising edge of CLK while TXFR\# is low. (Active low.) |
| DREF0-7 | $\begin{aligned} & \text { F1, G2, H1, H2, } \\ & \text { J1, J2, K1, L1 } \end{aligned}$ | I | DREF0-7 is an 8-bit wide data reference input. This is the input data bus used to load the reference data. RLOAD\# going active initiates the loading of the reference registers. This input bus is used to load the reference registers of the correlation array. The manner in which the reference data is loaded is determined by the window configuration. If the window configuration is $1 \times 256$, the reference bits are loaded one at a time over DREF7. When the HSP45256 is configured as an $8 \times 32$ array, the data is loaded into all stages in parallel. In this case, DREF7 is the reference data for the first stage and DREFO is the reference data for the eighth stage. The contents of the reference data registers are not affected by changing the window configuration. DREFO is the LSB. |
| RLOAD\# | K3 | 1 | RLOAD\# enables loading of the reference registers. Data on DREF0-7 is loaded into the preload registers on the rising edge of RLOAD\#. This data is transferred into the correlation array by TXFR\#. (Active low.) |
| DCONT0-7 | $\begin{aligned} & \text { J6, J7, K6, K7, } \\ & \text { L5-L8 } \end{aligned}$ | 1 | DCONTO-7 is the control data input, which is used to load the mask bit for each tap as well as the configuration registers. The mask data is sequentially loaded into the eight stages in the same manner as the reference data. DCONT0 is the LSB. |
| CLOAD\# | K4 | 1 | CLOAD\# enables the loading of the data on DCONT0-7. The destination of this data is controlled by A0-2. (Active low.) |
| A0-2 | J5, K5, L4 | 1 | A0-2 is a 3-bit address that determines what function will be performed when CLOAD\# is active. This address bus is set up with respect to the rising edge of the load signal, CLOAD\#. AO is the LSB. |
| AUXOUTO-8 | $\begin{aligned} & \mathrm{H} 10, \mathrm{H} 11, \mathrm{~J} 11, \\ & \text { K9-K11, L9-L11 } \end{aligned}$ | 0 | AUXOUTO-8 is a 9-bit bus that provides either the data reference output or the 9-bit correlation score of the second correlator, depending on the configuration. When the user programs the chip to be two separate correlators, the score of the second correlator is output on this hus. When the יseor has programmed the chip to ta uño courioiatui, AUXOUTO-7 represents the reference data out, with the state of AUXOUTO-8 undefined. AUXOUTO is the LSB. |
| OEA\# | K8 | I | The OEA\# signal is the output enable for the AUXOUT0-8 output. When OEA\# is high, the output is disabled. Processing is not interrupted by this pin. (Active low.) |
| Index Pin | C3 |  | Used for orienting pin in socket or printed cirecuit board. Must be left as a no connect in circuit. |

## Absolute Maximum Ratings



## Reliability Information

 Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic PGA Package . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.39W

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
TABLE 1. DC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 0.8 | V |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical Zero Input Voltage Clock | VILC | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\text {OL }}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\mathbb{N}}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | $I_{\text {ccss }}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | $\mathrm{I}_{\text {ccop }}$ | $\begin{aligned} & f=20 \mathrm{MHz}, \mathrm{~V}_{\mathbb{I}}=\mathrm{V}_{\mathrm{CC}} \\ & \text { or GND, } \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 140 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $7 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

Specifications HSP45256/883
TABLE 2. AC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -25 (25.6MHz) |  | -20 (20MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\text {CP }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLOAD\# Cycle Time | TCLC |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| CLOAD\# High | $\mathrm{T}_{\text {CLH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLOAD\# Low | $\mathrm{T}_{\text {cll }}$ |  | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| RLOAD\# Cycle Time | $\mathrm{T}_{\text {RLC }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| RLOAD\# High | $\mathrm{T}_{\text {RLH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | $\bullet$ | 20 | - | ns |
| RLOAD\# Low | $\mathrm{T}_{\text {RLL }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Set-up Time; DIN to CLK High | $\mathrm{T}_{\mathrm{DS}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| Hold Time; DIN to CLK High | $\mathrm{T}_{\mathrm{DH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Set-up Time; DREF to RLOAD High | $\mathrm{T}_{\text {RS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 14 | - | 15 | - | ns |
| Hold Time; DREF to RLOAD High | $\mathrm{T}_{\text {RH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| DCONT Set up Time | Tocs |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| DCONT Hold Time | $\mathrm{T}_{\mathrm{DCH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Address Set up Time | $\mathrm{T}_{\text {AS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| TXFR\# Set up Time | $T_{\text {TS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| TXFR\# Hold Time | $T_{\text {TH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| CLK to Output Delay DOUT, AUXOUT, CASOUT | $T_{\text {D }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 25 | ns |
| Output Enable Time | $\mathrm{T}_{\text {OE }}$ | Note 2 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| TXFR\# High to CLK Low | $\mathrm{T}_{\text {THCL }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 4 | $\bullet$ | ns |
|  CLOAD\# High | $\mathrm{T}_{\text {CLLH }}$ | Nutio | S, it, it | $-55^{n} \leq T_{A} \leq+i 25^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |

NOTES:

1. AC testing is performed as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 3.0 V and 0 V ; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transistion is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Transistion is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, $C_{L}=40 \mathrm{pF}$.
3. Applicabie only when TXFR\# and RLOAD\# or CLOAD\# are active on the same cycle of CLK.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -25 |  | -20 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Min | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | $\text { vCC }=\text { Open, } f=1$ <br> MHz All measurements are referenced to device GND. | 1 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Capacitance | Cout |  | 1 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Disable Time | TOD |  | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $T_{F}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

NOTES:

1. The parameters in Table 3 are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples/5005 | $1,7,9$ |

## Test Load Circuit



SWITCH S1 OPEN FOR I Iccse AND ICCOP TEST

HSP45256/883
Burn-In Circuits


| PGA PIN | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| A1 | CASIN2 | F3 |
| A2 | CASIN4 | F5 |
| A3 | CASIN5 | F6 |
| A4 | CASIN7 | F1 |
| A5 | CASIN10 | F4 |
| A6 | CASIN11 | F5 |
| A7 | CASOUTO | $\mathrm{V}_{\mathrm{C}} / 2$ |
| A8 | CASOUT3 | $V_{c c^{12}}$ |
| A9 | CASOUT5 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| A10 | GND | GND |
| A11 | CASOUT8 | $\mathrm{V}_{\mathrm{CO}} / 2$ |
| B1 | GND | GND |
| B2 | CASIN1 | F2 |
| B3 | CASIN3 | F4 |
| B4 | CASIN6 | F7 |
| B5 | CASIN9 | F3 |
| B6 | CASOUT2 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| Q? | CACOLT: | V'cóz |
| B8 | CASOUT4 | $\mathrm{V}_{\mathrm{c}}{ }^{\prime 2}$ |
| B9 | CASOUT6 | $\mathrm{V}_{\mathrm{cc}}{ }^{12}$ |
| B10 | CASOUT7 | $\mathrm{Vcc}^{12}$ |


| PGA <br> PIN | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| B11 | CASOUT10 | $\mathrm{V}_{\mathrm{c}}{ }^{12}$ |
| C1 | CLK | F0 |
| C2 | CASINO | F1 |
| C5 | CASIN8 | F2 |
| C6 | CASIN12 | F6 |
| C7 | OEC\# | F11 |
| C10 | CASOUT9 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| C11 | CASOUT11 | $\mathrm{V}_{\mathrm{C}}{ }^{\prime 2}$ |
| D1 | DIN7 | F8 |
| D2 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ |
| D10 | GND | GND |
| D11 | CASOUT12 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| E1 | DIN4 | F5 |
| E2 | DIN5 | F6 |
| E3 | DIN6 | F7 |
| E9 | DOUTO | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| E10 | DOUT1 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| E11 | DOUT2 | $\mathrm{V}_{\mathrm{cc}} / 2$ |
| F1 | DREF6 | F7 |
| F2 | DIN3 | F4 |
| F3 | DIN2 | F3 |


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| F9 | DOUT4 | $\mathrm{V}_{\mathrm{C}}{ }^{2}$ |
| F10 | DOUT7 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| F11 | DOUT3 | $V_{C C^{\prime}} 2$ |
| G1 | DINO | F1 |
| G2 | DREF7 | F8 |
| G3 | DIN1 | F2 |
| G9 | $\mathrm{V}_{\mathrm{Cc}}$ | $\mathrm{V}_{\mathrm{Cc}}$ |
| G10 | DOUT6 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| G11 | DOUT5 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| H1 | DREF5 | F6 |
| H2 | DREF4 | F8 |
| H10 | AUXOUT1 | $\mathrm{V}_{\mathrm{C}}{ }^{2}$ |
| H11 | AUXOUTO | $\mathrm{V}_{\mathrm{CC}}{ }^{2}$ |
| J1 | DREF3 | F7 |
| J2 | DREF1 | F5 |
| J5 | A1 | F10 |
| J6 | DCONT5 | F6 |
| J7 | DCONT4 | F8 |
| J10 | GND | GND |
| J11 | AUXOUT2 | $\mathrm{V}_{\mathrm{c}} / 2$ |
| K1 | DREF2 | F6 |


| $\overline{P G A}$ PIN | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-AN SIGNAL |
| :---: | :---: | :---: |
| K2 | $V_{\text {Cc }}$ | $V_{\text {cc }}$ |
| K3 | RLOAD\# | F3 |
| K4 | CLOAD\# | F3 |
| K5 | AO | F9 |
| K6 | DCONT6 | F7 |
| K7 | DCONT2 | F6 |
| K8 | OEA\# | F11 |
| K9 | AUXOUT6 | $\mathrm{V}_{\mathrm{cd}} / 2$ |
| K10 | AUXOUT4 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| K11 | AUXOUT3 | $\mathrm{V}_{\mathrm{Cd}}{ }^{2}$ |
| L1 | DREFO | F4 |
| L2 | GND | GND |
| L3 | TXFR\# | F2 |
| L4 | A2 | F11 |
| L5 | DCONT7 | F8 |
| L6 | DCONT1 | F5 |
| L7 | DCONT3 | F7 |
| L8 | DCONTO | F4 |
| L9 | AUXOUT8 | $\mathrm{V}_{\mathrm{CC}}{ }^{2}$ |
| L10 | AUXOUT7 | $\mathrm{V}_{\mathrm{cc}}{ }^{2}$ |
| L11 | AUXOUT5 | $\mathrm{V}_{\mathrm{cc}}{ }^{2}$ |

NOTES:

1. $\mathrm{V}_{\mathrm{C}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{k} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $F O=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots F 11=F 10 / 2,40-60 \%$ Duty Cycle.
6. Input Voltage Limits: $V_{I L}=0.8 \mathrm{~V}$ max,$V_{I H}=4.5 \pm 10 \%$.

## Metal Topology

DIE DIMENSIONS:
$254 \times 214 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si} \mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY: $0.96 \times 10^{5} \mathrm{Alcm}^{2}$

## Metallization Mask Layout

HSP45256/883


CASIN1 (74)
CASINO (73) GND (72) CLK (71)
VCC (70)
DIN7 (69)
DIN6 (68)
DIN5 (67)
DINA (66)
DIN3 (65)
DiN2 (64)
DIN1 (63)
DINO (62)
DREF7 (61)
DREF6 (60)
DREF5 (59)
DREF4 (58)
DREF3 (57)
DREF2 (56)
DREF1 (55)
DREFO (54)


HSP9520, HSP9521

## Features

- Four 8-Blt Registers
- Hold, Transfer and Load Instructions
- Single 4-Stage or Dual-2 Stage Pipelining
- All Register Contents Avallable at Output
- Fully TTL Compatible
- Three-State Outputs
- High Speed, Low Power CMOS


## Applications

- Array Processor
- Digital Signal Processor
- AD Buffer
- Telecommunication
- Byte Wide Shift Register
- Mainframe Computers


## Ordering Information

| PART NUMBER | TEMPERATURE <br> RANGE | PACKAGE |
| :--- | :---: | :--- |
| HSP9520CP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 24 Lead Plastic DIP |
| HSP9520CS | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 24 Lead SOIC |
| HSP9521CP | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 24 Lead Plastic DIP |
| HSP9521CS | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 24 Lead SOIC |

## Description

These devices are multilevel pipeline registers implemented using a low power CMOS process. They are pin for pin compatible replacements for industry standard muitilevel pipeline registers such as the L29C520 and L29C521. The HSP9520 and HSP5921 are direct replacemens for the AM29520 and AM29521 and WS59520 and WS59521.

They consist of four 8-bit registers which are dual ported. They can be configured as a single four level pipeline or a dual two level pipeline. A single 8-bit input is provided, and the pipelining configuration is determined by the instruction code input to the IO and II inputs (see instruction control).

The contents of any of the four registers is selectable at the multiplexed outputs through the use of the S0 and S1 multiplexer control inputs (see register select). The output is 8 -bits wide and is three-stated through the use of the OE\# input.

The HSP9520 and HSP9521 differ only in the way data is loaded into and between the registers in dual two-level operation. In the HSP9520 when data is loaded into the first level the existing data in the first level is moved to the second level. In the HSP9521 loading the first level simply causes the current data to be overwritten. Transfer of data to the second level is achieved using the single four level mode (11, $10=$ ' 0 '). This instruction also causes the first level to be loaded. The HOLD instruction ( $11,10={ }^{\prime} 1$ ') provides a means of holding the countents of all registers.

## Pinout



## Block Diagram



## Pin Descriptions

| NAME | DIP PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 24 |  | The +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and GND pin is recommended. |
| GND | 12 |  | The device ground. |
| CLK | 11 | 1 | Input Clock. Data is latched on the low to high transition of this clock signal. Input setup and hold times with respect to the clock must be met for proper operation. |
| DO-7 | 3-10 | I | Data Input Port. These inputs are used to supply the 8 bits of data which will be latched into the selected register on the next rising clock edge. |
| YO-7 | 21-14 | 0 | Data Output Port. This 8-bit port provides the output data from the four internal registers. They are provided in a multiplexed fashion, and are controlled via the multiplexer control inputs (SO and S1). |
| 10,11 | 1,2 | 1 | Instruction Control Inputs. These inputs are used to provide the instruction code which determines the internal register pipeline configuration. Refer to the instruction Control Table for the specific codes and their associated contigurations. |
| S0, 51 | 23, 22 | I | Multiplexer Control Inputs. These inputs select which of the four internal registers' contents will be available at the output port. Refer to the Register Select Table for the codes to select each register. |
| OE\# | 13 | I | Output Enable. This input controls the state of the output port (YO-Y7). A LOW on this control line enables the port for ouput. When OE\# is HIGH, the output drivers are in the high impedance state. Internal latching or transfer of data is not affected by this pin. |

Absolute Maximum Ratings
Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.0 V
Input or Output Voltage Applied $\ldots . . .$. . GND -0.5 V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, Ten Seconds) ............. $+300^{\circ} \mathrm{C}$

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . +4.75 V to +5.25 V
Operating Temperature Range $\ldots \ldots \ldots \ldots . . . . . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Reliability Information

D.C. Electrical Specifications $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $V_{C C}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V | $\mathrm{I}^{\mathrm{OH}}=-6.5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.5 | V | $\mathrm{I}_{\mathrm{OL}}=+20.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Standby Power Supply Current | ${ }^{\text {I Ccse }}$ | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 V \text { Outputs Open } \end{aligned}$ |
| Operating Power Supply Current | ICCOP | - | 12 | mA | $\begin{aligned} & f=5.0 \mathrm{MHz}, \mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \text {, Ouputs Open, Note } 1 \end{aligned}$ |

Capacitance $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$, Note 3)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CIN | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | CO | - | 12 | pF |  |

A.C. Electrical Specifications $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS (Note 2) |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Clock to Data Out | TPD | - | 21 | ns |  |
| Mux Select to Data Out | TSELD | - | 20 | ns |  |
| Input Setup Time (D0-7/I0-7) | TS $_{\text {S }}$ | 10 | - | ns |  |
| Input Hold Time (DO-7/I0-7) | TH $_{\text {H }}$ | 3 | - | ns |  |
| Output Enable Time | TENA | - | 20 | ns |  |
| Output Disable Time | TDIS | - | 13 | ns | Note 3 |
| Clock Pulse Width | TPW | 10 | - | ns |  |

NOTES:

1. Power supply current is proportional to frequency. Typical rating for IC $\cap$ no is $2.4 \mathrm{~mA} / \mathrm{MHz}$.
2. A.C. Testing is performed as follows: Input levels: OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{N}$, Output load $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Controled by design or process parameters and not directly tested. Characterized upon initial design and after major design and/or process changes.

Timing Waveform


TABLE 1. INSTRUCTION CONTROL


TABLE 2. REGISTER SELECT

| $S 1$ | So | '9520 OR'9521 |
| :---: | :---: | :---: |
| 0 | 0 | $B 2$ |
| 0 | 1 | $B 1$ |
| 1 | 0 | $A 2$ |
| 1 | 1 | $A 1$ |

## $-\quad-\quad-$

DEVELOPMENT TOOLS

PAGE

## DEVELOPMENT TOOLS DATA SHEETS

DECI•MATE ${ }^{\text {TM }} \quad$ Harris HSP43220 Decimating Digital Filter Development Software . . . . . . . . . . . . . . . 8-3
HSP-EVAL DSP Evaluation Platform. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-7
HSP45116-DB HSP45116 Daughter Board. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-8
HSP50016-EV DDC Evaluation Platform . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-10

NOTE: Bold Type Designates a New Product from Harris.

# Harris HSP43220 Decimating Digital Filter Development Software 


#### Abstract

Harris DECI - MATE Development Software assists the design engineer to prototype designs for the Harris HSP43220 Decimating Digital filter (DDF). Developed specifically for the DDF, this software consists of three integrated modules: DDF Design, DDF Simulator and DDF PROM. The Design module designs a filter from a set of user specifications for the DDF. The Simulator module models the DDF's internal operation. The PROM module uses the device configuration created by the Design module to build a PROM data file that can be used to store and download the DDF configuration.


## DDF System Design

The DDF consists of two stages: a High Decimation Filter (HDF) and a Finite Impulse Response (FIR) filter. Together these provide a unique narrow band, low pass filter. Because of this unique architecture, special software is required to configure the device for a given set of filter parameters. This software uses system level filter parameters (listed below) to perform the trade off analysis and calculate the values for the DDF's configuration registers and FIR coefficients.

Design specifications are supplied by the user in terms of:

1. Input sample frequency
2. Required output sample frequency
3. Passband signal bandwidth
4. Transition bandwidth
5. Amount of attenuation allowed in the passband
6. Amount of stopband attenuation required for signals outside of the band of interest.
This information is entered into a menu screen (See Figure 1), providing immediate feedback on the design validity. The design module calculates the order of the HDF, HDF decimation required, the FIR input data rate, minimum clock frequency for the FIR, FIR order and decimation required in the FIR.

The design module will then generate the FIR filter. Four different methods are provided for the FIR design:

1. A Standard FIR automatically designed by the module using the Parks-McClellan method to compute the coefficients of an equiripple (Chebyshev) filter.
2. Any FIR imported into the Design module from another FIR design program.
3. A precompensated FIR which is automatically designed by the module to compensate for the roll-off in the passband of the HDF frequency response.
4. The FIR may also be bypassed in which case the optimal HDF is designed from the user specifications.

Frequency response curves are then displayed showing the resulting responses in the HDF, FIR and for the entire chip using the given filter design. Figure 2 is a typical display. The user may save this frequency response data for further analysis. The design module also creates a report file documenting the filter design and providing the coefficients and setup register values for programming the device.

## DDF Simulator

The simulator provides an accurate simulation of the device before any hardware is built. It can be used to simulate any filter designed with DECI • MATE. The simulator takes into account the fixed point bus widths and pipeline delays for every element in the DDF.

The simulator provides the user with an input signal which can be used to stimulate the filter. This signal is created from the options shown in Table 1. The user can select a pure step, impulse, cosine, chirp, uniform or Gaussian noise as the input signal, or a more complex signal can be generated by combining that data with an option selected from the Signal \#2 column, with the combining operator chosen from the middle column. The user can also import a signal from an outside source.

TABLE 1.

| SIGNAL \#1 | OPERATION | SIGNAL \#2 |  |
| :--- | :--- | :--- | :---: |
| Step |  | Step |  |
| Impulse | No Operation | Impulse |  |
| COSINE | Add | COSINE |  |
| Chirp | Concatenate | Chirp |  |
| Uniform Noise | Multiply | Uniform Noise |  |
| Gaussian Noise | Imported From Outside |  |  |
|  |  |  |  |

Probes are provided to select specific areas to graphically display data values as well as save into data files for further processing. The DDF Simulator has two levels; the DDF Simulator Specification screen and the DDF Simulator Main Screen.

The specification screen (see Figure 3) is used to input the simulation parameters. The users selects display modes in either continuous or decimated format and data formats in either decimal or hexadecimal. The specification screen also provides for selection of the input signal.
The simulator main screen (see Figure 4) defines the simulator test probes and displays the data values per clock cycle. The interactive simulator screen consists of the HSP43220 block diagram, test probes and register contents. The user selects the step size of the input sample clock and also selects the probes to be monitored. The simulator will then clock through the specified number of clock cycles and display the resulting time domain response. Figure 5 shows a typical probe display.

## Monarch 2.0 DSP Design Software

DECI•MATE is fully integrated with Monarch 2.0 professional DSP design software. Monarch is a fullfeatured DSP package with FIR IIR filter design and analysis, Two dimensional and Three dimensional viewing, a programmable signal/systems laboratory with $100+$ DSP/ Math functions, extensive fixed-point support and FFTs/ IFFTs. Monarch is available separately from The Athena Group, Inc.

When used with Monarch 2.0, DECI • MATE becomes a full feature design environment for a DSP system. Data can easily be transferred from DECI• MATE modules to the Monarch modules for further analysis.

## System Requirements

IBM PC ${ }^{m}, \mathrm{XT}^{\text {mu }}, \mathrm{AT}^{\mathrm{mw}}, \mathrm{PS} / 2^{\mathrm{mm}}$ computer or $100 \%$ compatible with 640k RAM running MS/PC-DOS 2.0 or higher. One MegaByte of fixed-disk space with 5.25 " or $3.5^{\prime \prime}$ floppy drive. CGA, MCGA, EGA, VGA, 8514, or Hercules graphics adapter. A Math co-processor is strongly recommended.


FIGURE 1. FILTER SPECIFICATION MENU


FIGURE 2. FREQUENCY DISPLAY


| D |
| :---: |
| E |
| C |
| I |
| $\bullet$ |
| M |
| A |
| T |



FIGURE 3. SPECIFICATION MENU


FIGURE 4. SIMULATOR - MAIN MENU


FIGURE 5. SIMULATOR PROBE DISPLAY

SEMICONDUCTOR

## Features

- Single HSP-EVAL May be Used to Evaluate a Variety of Parts Within the HSPXXXXX Family of DSP Products
- May be Dalsy Chained to Support Evaluation of Multi-chip Solutions
- Parallel Port Interface to Support IBM PC ${ }^{\text {TM }}$ Based Evaluation and Control
- Three Clocking Modes for Flexibility in Performance Analysis and Prototyping
- Dual 96-Pin Input/Output Connectors Conforming to the VME J2/P2 Connector Standard


## Applications

- PC Based Performance Analysis of HSPXXXXX Family of DSP Products
- Rapid Prototyping


## Description

The HSP-EVAL is the mother board for a set of daughter boards based on the HSPxxxxx family of Digital Signal Processing products. Each product specific daughter board is mated with the HSP-EVAL to provide a mechanism for rapid evaluation and prototyping. As shown in Figure 1, the HSP-EVAL consists of a series of busses which provide input, output, and control to the target daughter board. These busses are brought out through dual 96 Pin connectors to support daisy chaining HSP-EVAL's for multichip prototyping and evaluation.

For added flexibility, the input and control busses can be driven by registers on-board the HSP-EVAL which have been down loaded with data via the parallel port of an IBM PC ${ }^{\text {TM }}$ or compatible. In addition, a shift register is provided to serialize data on the daughter board output busses for reading into the PC via the status lines of the paraliel port. Together, the I/O and Control registers can be used to drive the target daughter board with a PC based vector set while collecting daughter board outputs to the PC's disk.

Jumper selectable clock sources provide three different methods of clocking the part under evaluation. In mode one, the clock signal is generated under PC based software control. In mode two, the HSP-EVAL's on-board oscillator may be selected as the clock source. In mode three, the user may provide an external clock through the 96 Pin Input Connector.

The HSP-EVAL was built into a 3U Euro-Card form factor with dual 96Pin input/Ouput connectors. The I/O connectors conform to the VME J2/P2 connector standard.

DSP Evaluation Platform


## HSP45116-DB

## USER'S MANUAL

## Features

- Designed for use with HSP-EVAL
- Access to HSP45116's input, output, and control signals through three 50 Pin Headers
- HSP45116 control signal states may be set through hardware configuration or software.
- Two separate software packages for daughter board 1/O and control
- High speed VO supported


## Applications

- PC Based performance analysis of HSP45116 when used with HSP-EVAL
- Rapid prototyping


## Description

The HSP45116-DB is a daughter board designed to mate with the HSP-EVAL for rapid evaluation and prototyping of the HSP45116 Numerically Controlled Oscillator Modulator. Together, the board set provides a mechanism to evaluate HSP45116 operation using IBM PC ${ }^{\text {TM }}$ based I/O and control. As shown in the Figure 1, the HSP45116-DB maps the input, output, and control signals of the HSP45116 to three 50 pin headers. These headers mate with connectors on board the HSPEVAL to interface the HSP45116's various I/O and control signals with the HSPEVAL's data busses. This interface establishes a path for PC ${ }^{\text {TM }}$ based I/O and control of the HSP45116-DB via the HSP-EVAL.

An IBM PC ${ }^{\text {TM }}$ based software package is supplied which controls operation to the HSP45116-DB/HSP-EVAL board set. The software package provides the user with a DOS command line interface and graphical user interface for daughter board I/O and control. Since the software supports data acquisition from the HSP45116, software based signal analysis may be used to quantify part performance.

The degree of control exerted by the software varies depending upon the clock supplied to the HSP45116-DB. If a high speed clock is supplied via the HSP-EVAL's on board oscillator or external clock pin, the software can be used to exert real time control. If a software controlled clock is provided, the HSP45116-DB can be driven with a user defined data set while storing results back to the PC for later analysis.

The HSP45116-DB is a 6 layer printed circuit board which comes populated with one HSP45116GC-25. The PC based software required to control the daughter board via the HSP-EVAL is also provided

## HSP45116 Daughter Board



[^7]

The evaluation hardware for the HSP family of products consists of the motherboard, which forms the interface to the PC, and the daughterboard, which carries the part under evaluation.


The hardware to evaluate the HSP45116 consists of the HSP-EVAL motherboard and the HSP45116-DB daughterboard. Two software packages are provided for the data and control interface between the HSP45116-DB and the PC. One is menu driven and the other accepts DOS command lines.

## USER'S MANUAL

## Features

- Single HSP50016-EV may be Used to Evaluate the HSP50016
- May be Daisy Chained to Support Evaluation of Multi-Chip Solutions
- Parallel Port Interface to Support IBM PC™ Based Evaluation and Control
- Three Clocking Modes for Flexibility in Performance Analysis and Prototyping
- Dual 96-Pin Input/Output Connectors Conforming to the VME J2/P2 Connector Standard


## Applications

- PC Based Performance Analysis of HSP50016
- Rapid Prototyping


## Description

The HSP50016-EV is the evaluation board for the HSP50016 Digital Down Converter (DDC). It provides a mechanism for rapid evaluation and prototyping. The HSP50016-EV consists of a series of busses which provide input, output, and control to the DDC. These busses are brought out through dual 96 Pin connectors to support daisy chaining HSP50016-EV's with other Harris evaluation boards for multichip prototyping and evaluation.

For added flexibility, the input and control busses can be driven by registers on-board the HSP50016-EV which have been down loaded with data via the parallel printer port of an IBM PC'™ or compatible. In addition, the DDC output can be read into the PC via the status lines of the parallel port. Together, the I/O and Control registers can be used to drive the target DDC with a PC based vector set while collecting output data on the PC's disk.

Jumper selectable clock sources provide three different methods of clocking the part under evaluation. In mode one, the clock signal is generated under PC based software control. In mode two, the HSP50016-EV's on-board oscillator may be selected as the clock source. In mode three, the user may provide an external clock through the 96 pin input connector.

The HSP50016-EV was built into a 3U Euro-Card form factor with dual 96 -pin Input/Ouput connectors. The I/O connectors conform to the VME J2/P2 connector standard.

## HSP50016 Evaluation Platform



IBM $P^{n}$ is a registered trademark of International Business Machines, Inc.

## APPLICATION NOTES AND TECH BRIEFS

PAGE

## APPLICATION NOTES

AN9401 Reducing the Minimum Decimation Rate of the HSP50016 Digital Down Converter ..... 9-3
AN116 Extended Digital Filter Configurations ..... 9-13
AN9205 Timing Relationships for HSP45240 ..... 9-23
AN9102 Noise Aspects of Applying Advanced CMOS Semiconductors ..... 9-25
AN9207 Temperature Considerations ..... 9-34
TECH BRIEFS
TB310 Common Abuses of the HSP43220 ..... 9-36
TB311 HSP43220 - Design of Filters with Output Rates <2(Passband + Transition) ..... 9-37
TB308 HSP43220 DECI•MATE Design Rule Checks ..... 9-39
TB309 Notes on Using the HSP43220 ..... 9-41
TB312 HDF Bypass in the HSP43220 ..... 9-44
TB313 Reading Out FIR Coefficients from the HSP43220 ..... 9-45
TB314 Quadrature Down Conversion with the HSP45116, HSP43168 and HSP43220 ..... 9-46
TB316 Pipeline Delay Through the HSP45116 ..... 9-53
TB319 Reading the Phase Accumulator of the HSP45106 ..... 9-54
TB317 Pipeline Delay Through the HSP45106 ..... 9-56
TB318 The NCO as a Stable, Accurate Synthesizer ..... 9-58
TB305 Histogramming with a Variable Pixel Increment ..... 9-61
TB306 Cascading Multiple HSP45256 Correlators. ..... 9-63
TB307 Correlation with Multibit Data Using the HSP45256 ..... 9-65


# Harris Digital Signal Processing 

## REDUCING THE MINIMUM DECIMATION RATE OF THE HSP50016 DIGITAL DOWN CONVERTER

## Introduction

This application note discusses a method for reducing the minimum decimation rate of the Harris HSP50016 Digital Down Converter (DDC). As will be described in detail in this application note, reduction in the minimum decimation rate is accomplished by first sample rate expanding the data stream which would normally be directly input to the DDC by a factor $L$ (placing L-1 zero valued samples between each sampled data point). While the sample rate expansion process reduces the maximum input sampling rate that the aggregate circuit (DDC and sample rate expander) can accept by a factor of L , the ratio of the maximum output bandwidth to input sample rate of the aggregate circuit is increased by a factor of $L$. The output bandwidths as a function of HDF decimation rate $M_{1}$, aggregate circuit input sample rate $f_{S A}$, and sample rate expansion $L$ are:

$$
\begin{align*}
& -3 \mathrm{~dB} \mathrm{BW}=0.13957 \mathrm{Lf}_{\mathrm{SA}} / M_{1}  \tag{1}\\
& -102 \mathrm{~dB} \mathrm{BW}=0.19903 \mathrm{Lf}_{\mathrm{SA}} / \mathrm{M}_{1} . \tag{2}
\end{align*}
$$

The DDC is a fully programmable single chip down converter architected to meet a wide range of down convert applications. A top level functional block diagram of the DDC architecture is shown in Figure 1. The principal goal of the DDC is to filter and translate a band of interest to baseband and to output the band of interest at a sample rate commensurate with its bandwidth.

Author: Dr. David B. Chester

The decimation occurs in a two step process. Once the center of the band of interest is shifted to DC by the quadrature modulator the real and imaginary outputs are each passed to a high decimation filter (HDF). The decimation rate of the HDFs, denoted $M_{1}$, is programmable from a minimum of 16 to a maximum of 32,768 . The outputs of the HDF filters must be scaled for gain compensation.

The lowpass response of the HDF has a gradual roll off characteristic requiring a subsequent conventional FIR to achieve a sharp transition. The DDC employs a fixed shaping filter for ease of use. The output bandwidth of the DDC is a function of the input sampling rate, the programmable HDF decimation rate and the fixed shape of the FIR. This relationship is:

$$
\begin{align*}
& -3 \mathrm{~dB} \mathrm{BW}=0.13957 \mathrm{ff}_{\mathrm{S}} / \mathrm{M}_{1}  \tag{3}\\
& -102 \mathrm{~dB} \mathrm{BW}=0.19903 \mathrm{f}_{\mathrm{S}} / \mathrm{M}_{1} \tag{4}
\end{align*}
$$

where BW is the double sided bandwidth and is is the input sample rate.

The FIR filter's passband compensates for the roll-off inherent in the passband of the HDF filter to meet the goal of a low passband ripple [1].

The FIR filter automatically decimates by a factor of 4 if a quadrature output format has been selected. When a real output is selected, the FIR filters in the DDC automatically decimate by a factor of 2 . The FIR decimation rate is


FIGURE 1. DDC FUNCTIONAL BLOCK DIAGRAM
denoted $\mathbf{M}_{\mathbf{2}}$. In the real output mode the FIR outputs are spectrally shifted by one fourth of the output sampling frequency and combined to produce a two sided spectrum. This process is conceptually performed by the Weaver Modulator [2] following the FIR filter pair.
For quadrature output mode we see that the minimum DDC decimation rate is

$$
\begin{equation*}
\min (M)=\min \left(M_{1}\right) \times M_{2}=16 \times 4=64 . \tag{5}
\end{equation*}
$$

The minimum decimation rate for real output mode is 32 .
The resulting signal is converted into one of several selectable formats for output. See reference [1] for a detailed description of the DDC and its operation.

A simple procedure can be used to reduce the minimum aggregate decimation rate of the DDC with a minimum of external circuitry. The trade-off in reducing the aggregate decimation rate is a one to one reduction in maximum input sampling rate.

## Reduction of the Minimum Decimation Rate

The minimum decimation rate of the DDC can be reduced by using a minimal amount of external circuitry to convert the DDC from a strictly decimating device to a rate change device. By doing this, the DDC and external circuitry can first interpolate the input signal to a higher sampling rate before decimating it. This restricts the sampling frequency, and correspondingly the bandwidth, of the input signal to be less than the clock frequency of the DDC. The result however is a reduction in the end-to-end decimation rate of the aggregate circuit.

A rate change filter is an interpolation filter combined with a decimation filter. The combining of the actual filtering processes is done by implementing the filter process that requires the narrowest bandwidth of the two.
Because interpolation via digital filtering is not introduced in the DDC data sheet, it is presented at a top level here.

## Interpolation

Interpolation is the increase in the sampling rate of a signal while preserving its original spectral content. The first step in interpolation is to stuff L-1 zero valued samples between each valid input sample to expand the sampling rate by a factor of $L$. The zero stuffing causes the original signal spectrum to be repeated L-1 times. To perform the actual interpolation the zero valued input samples must be converted to approximations of signal samples. This is equivalent to preserving the original signal spectrum. Thus, the zero stuffed input stream is filtered by a lowpass filter which has its passband at the original spectrum location and filters out all of the repeated spectra. This process is shown pictorially in Figure 2.

## Rate Change

The top level block diagram of a rate change filter [2] is shown in Figure 3A. In the diagram the sampling rate of the incoming signal is first expanded by a rate $L$ by placing $L-1$ zero valued samples between each original sample. The lowpass filter following the sample rate expander is designed to: 1) remove the L-1 spectral images which result from the zero padding; 2) multiply the result by a gain of $L$ to compensate for the power loss that occurs when the spectral images are removed; and 3) limit the width of the spectrum to allow sample rate compression by $M$ without aliasing. An example of this process is illustrated spectrally in Figure 3B.


FIGURE 2. BLOCK dIAGRAM SPECTRAL REPRESENTATION OF THE RATE CHANGE PROCESS


FIGURE 3A. TOP LEVEL BLOCK DIAGRAM OF A RATE CHANGE FILTER


FIGURE 3B. SPECTRAL REPRESENTATION OF THE RATE CHANGE PROCESS

The first and third design criteria are combined by taking the more severe (narrowest bandwidth \& shape factor) of the two.
In most implementations the least common denominator (LCD) of $L$ and $M$ is 1 . In the application described here this is not generally true because the DDC itself is not a rate change device.

## The DDC in a Rate Change Configuration to Reduce the Minimum Decimation Rate

Figure 4 shows a conceptual block diagram of the modulation and filter processes in one of the two real processing chains in the DDC. The two stage decimation filter configuration is a conventional architecture [2] with the exception of the scaling multiplier between the first sample rate compressor and the second lowpass filter. The scaling multiplier is used to compensate for the variable gain of the programmable HDF [1,3,4,5,].
The input to the DDC is first multiplied by a sinusoid from the digital local oscillator (LO). The sinusoids for the inphase and quadrature paths are offset in phase by 90 degrees. The product is passed to the HDF.

Placing a sample rate expander in front of the HDF and using the fact that the multiplication of the input signal by the LO is a linear operation we can redraw Figure 4 to get the rate change capability shown in Figure 5.

In the configuration shown in Figure 5 it is assumed that the constraint placed on the lowpass filtering by decimation is more severe than the interpolation constraint. This is in general the case when the decimation rate of the DDC is higher than the interpolation rate being generated by the external sample rate expander.

From Figure 5 it can be seen that the sample rate of the input to the sample rate expander has a maximum value of clk/L where clk is the DDC clock.

The sample rate expander can be constructed simply as a divide by L counter and a series of AND gates. Example implementations are shown later in this applications note.

## Example: Decimation By 8

As an example case we will use the DDC to decimate by 8 with a quadrature output. In this example the HDF section is programmed to decimate by the minimum value of 16 and the FIR section automatically decimates by 4 . The aggregate DDC decimation rate is $16 \times 4=64$. To get a decimation rate of 8 we must interpolate by

$$
\begin{align*}
L & =\frac{\text { DDC Decimation }}{\text { Desire Decimation }}  \tag{6}\\
& =64 / 8=8
\end{align*}
$$

The sample rate expander therefore pads 7 zero samples between each sample that enters it. The maximum sampling frequency of the input signal is clk/8. For a maximum DDC clock of 75 MHz the maximum input clock for this example is 9.375MHz.

Assume that the input signal is wideband and that it is sampled at 2.5 times the highest frequency of interest. The resulting spectrum at the input to the sample rate expander is shown in Figure 6. Notice in the figure that to relax the anti-aliasing filter design, aliasing is allowed to occur at frequencies above the maximum frequency of interest.

When the input signal has passed through the sample rate expander and has been padded with 7 zero samples between each input sample the one sided spectrum illustrated in Figure 7 results. Also shown in the figure is the HDF lowpass response. Notice that the power in the original signal and each image is reduced by 18 dB from the input power level, defined as OdB in the figure. This phenomenon occurs in digital interpolation because padding by L-1 zeros adds L1 spectral repetitions without adding power.

The interpolation process is completed by removing the spectral images via a lowpass filter operation. This loss of power of $20 \times \log (\mathrm{L}) \mathrm{dB}$ in the filtering operation would result in a corresponding loss in dynamic range if it is not corrected for.

FIGURE 4. CONCEPTUAL BLOCK DIAGRAM OF ONE SIDE OF THE DDC MODULATION AND FILTER PROCESS


FIGURE 5. CONCEPTUAL BLOCK DIAGRAM OF ONE SIDE OF THE DDC MODULATION AND FILTER PROCESS WITH A SAMPLE RATE EXPANDER


FIGURE 6. SPECTRUM OF DIGITAL INPUT SIGNAL


FIGURE 7. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE SUPERIMPOSED


## FIGURE 8. TOP LEVEL BLOCK DIAGRAM OF THE HIGH DECIMATION FILTER

The output -3dB bandwidth can be calculated from equation 1 where $f_{S A}$ is equal to 9.375 megasamples per second (MSPS). We get:
$-3 \mathrm{~dB} \mathrm{BW}=0.13957 \times 8 \times 9.375 \mathrm{MSPS} / 16=654.234 \mathrm{kHz}$.
From this result we see that for a DDC clock of 75 MHz the maximum output bandwidth has not changed. What has changed is the maximum output bandwidth relative to the actual input sample rate of 9.375 MSPS.

## Implementation Details

Figure 8 shows a more detailed block diagram of the HDF. The HDF is an efficient, multiplier free, decimating lowpass filter for moderate to high denimation rates[3]. As shiuwii in the figure, the HDF actually decimates before completion of the filtering process. However, the process is functionally equivalent to the process of filtering by LPF1 followed by sample rate compression by a rate $\mathrm{M}_{1}$ shown in Figure 4.
The frequency domain response of an unscaled HDF is:

$$
\begin{equation*}
H(f)=\left(\operatorname{Sin}(\pi f) / \operatorname{Sin}\left(\pi f / M_{1}\right)\right)^{5} \tag{7}
\end{equation*}
$$

The DC gain of this response is $M_{1}{ }^{5}$. This gain must be com-
pensated for by multiplying by the inverse of the DC gain. The gain compensation is distributed between the input and output of the HDF in the DDC implementation. The gain compensation at the input of the HDF is accomplished via a shift register labeled the Input Data Shifter in Figure 8. Consequently, this gain compensation is in the form of powers of two. The gain compensation at the output of the HDF is accomplished via a multiplier. The multiplier compensates for non powers of two in the gain compensation.

The HDF Input Data Shifter positions the input data, as a function of the HDF decimation rate, so that the MSB of the output data will be aligned with the MSB of the output bus. The data shifter is programmed in terms of a data shift value. That is, the number of bits between the LSB of the input to the $\mathrm{H} \overline{\mathrm{LF}}$ F and the LSB of the HDF. The data shift equation is:

$$
\begin{equation*}
\text { Data Shift }=75-\text { Ceiling }\left(5 \log _{2}\left(M_{1}\right)\right) \tag{8}
\end{equation*}
$$

where Ceiling $(\mathbf{X})$ denotes taking the next greatest integer if $X$ has a non integer component. In point of fact, the shift divides the HDF gain by a value which is greater than or equal to $M_{1}{ }^{5}$ to guarantee that the input to the scaling multiplier is between 0.5 non inclusive and 1 inclusive. For a detailed explanation see reference [3].

After the data shift has been performed the HDF gain at the output is given by

$$
\begin{equation*}
\text { HDF Gain } \left.=M_{1}^{5} / 2^{\text {CEILING(5LOG }} 2\left(M_{1}\right)\right) \tag{9}
\end{equation*}
$$

The compensating scale factor, which is the input to the Scaling Multiplier quantized to 16 bits, is given by the equation:

$$
\begin{equation*}
\text { Scale Factor } \left.=2^{\text {CEILING(5LOG }} 2\left(M_{1}\right)\right) / M_{1}{ }^{5} \tag{10}
\end{equation*}
$$

The computed scale factor can take on values from 1 inclusive to 2 non inclusive. The programmable quantized scale factor can take on values from 0 to $2-2^{-15}$.

The validity of the HDF gain equation is predicated on the correct programming of the HDF data shifter. See referenced [1] for details.

The following two examples are used to illustrate the gain compensation procedure.

Example 1: $\mathrm{M}_{1}=512$
In this example we are decimating by a power of 2 . The Data Shift value is
$75-$ Ceiling $\left(5 \log _{2}(512)\right)=30$.
The Scale Factor value is
$2^{\text {CEILING(5LOG }}{ }_{2}^{(512))} / 512^{5}=1$.
Example 2: $M_{1}=513$
The Data Shift value is
$75-$ Ceiling $\left(5 \log _{2}(513)\right)=29$.
The Scale Factor value is
$2^{\text {CEILING(5LOG }}{ }_{2}(513) / 513^{5}=1.98058267$

## Interpolation Gain Compensation

An explanation of how to preserve the DDC's dynamic range when reducing its minimum decimation rate is now given in detail. In most normal operating conditions this procedure is simple and straight forward. Under certain worst case conditions however, special considerations must be made. We describe the straight forward case first. We then describe how to handle the worst case conditions.

The removal of spectral images created in the sample rate expansion process is accomplished by the lowpass filtering in the DDC. As mentioned above, the removal of the images results in a loss in gain since no power is added to the signal during the sample rate expansion process. Power is removed in the lowpass filter process. Dynamic range through the DDC can be preserved by compensating for the gain loss due to the spectral image removal by adjusting the gain through the HDF.
Because the lowpass filter process is a two step process involving the HDF and FIR, the HDF may not suppress all images to the attenuation required to prevent overflow during the standard scaling process. This is the case in Figure 14 as will be explained in detail below. As long as the images are suppressed sufficiently to preclude overflow in the HDF and scaling operation however, no distortion occurs in the process.

## Standard Gain Compensation

For an example of standard gain compensation, assume that an overall decimation rate of 4 is desired in the DDC. The input samples are expanded by 16 by placing 15 zero valued samples between each input sample. The resulting spectrum is illustrated in Figure 9.
(Note: Figures 9 through 24 show the repeated input spectrum superimposed on the HDF response curve. These superimpositions assume that the down convert frequency is zero. The analysis holds for any valid down convert frequency. Also shown in the figures by the vertical solid lines are the positions of the images of near DC areas of the spectra.)

Assume that the input signal consists of two equal amplitude tones, one at DC (desired in this example) and one at $4 / 5$ of the pre-expanded input sampling frequency (to be ultimately rejected in this example). In the expanded spectrum the DC component repeats as illustrated by the vertical solid lines in Figure 9 and the $4 / 5$ sampling frequency tone is repeated at each interface between the two shaded areas in the figure. Each tone is at -6dB on the pre-expanded input and down 30 dB on the expanded spectrum.

To compensate for the gain loss due to the rejection of images requires a 24 dB gain in the HDF. The requirement to prevent overflow in the gain compensation operation is that the sum of the signal power after compensation is $\leq 0 \mathrm{~dB}$.

As can be seen in Figure 9 all DC images lie in the HDF nulls. Since the original DC component is at -6 dB after compensation it is required that the sum of the power in the original $4 / 5$ sampling frequency tone and it's images be $\leq-6 \mathrm{~dB}$ after compensation. From the HDF curve it is determined that the total power from the tone and its images is approximately -10.9 dB . As a result no overflow will occur in the HDF or scaling multiplier due to gain compensation. The residual signals are then filtered in the FIR.
The compensation scale factor required is equal to the interpolation factor, L. Combining the interpolation gain compensation with the HDF response gain compensation we have a total compensation of $L / M_{1}{ }^{5}$. We now rewrite equations 8 and 10 to incorporate the interpolation gain compensation.

$$
\begin{equation*}
\text { Data Shift }=75-\text { Ceiling }\left(\log _{2}\left(M_{1} 5 / L\right)\right) \tag{11}
\end{equation*}
$$

Scale Factor =

$$
\begin{equation*}
\text { L2 }^{\text {CEILING }\left(\operatorname{LOG}_{2}\left(M_{1} / L\right)\right) / M_{1}^{5}} \tag{12}
\end{equation*}
$$

Equations 11 and 12 are used when no overflow is possible in the HDF as a result of the interpolation and scaling process.
Special Case 1 - Overflow Possibilities When the Interpolation Factor is Less Than or Equal to the HDF Decimation Factor

Figures 9 through 23 show interpolated spectra superimposed on the HDF filter response curve for interpolation cases 16 through 2. The figures are supplied to illustrate the possibility of overflow in the extreme case where full scale inputs to the DDC are supplied and all of the dominant spectral components meet two criteria. First, they are all
within $1 / 125$ th of the main lobe and second, the majority of them generate an image or images that lie at the peaks of the first or second side lobe. (The peak value of the first HDF sidelobe is $1.168 \times 10^{-4}$ which is approximately equal to 1 the magnitude of the mainlobe at a frequency of $1 / 125$ th of the first HDF null.)
(Note: the above paragraph describes a condition, specifically a full scale input, which should not occur in typical operations. The description of this special case is included for completeness.)

To illustrate the potential for overflow in the extreme case described above we select a full scale single tone input which is mixed to DC in the down convert section of the DDC. The dark vertical lines in the figures highlight DC images. Examining Figure 14, the interpolate by 11 example, we see that the first image lies at 6.818 MHz for a 75MSPS DDC input rate. This image is very near the 6.713 MHz peak of the first HDF sidelobe.

The attenuated magnitude of the first and second images and fifth and sixth (not including the attenuation due to sample rate expansion) sum to approximately $5.109 \times 10^{-4}$. As a result, if equations 11 and 12 are used for gain compensation then the peak signal value coming out of the HDF would be 1.0005109 and the HDF would overflow. This would generate catastrophic errors.

To correct for the image components we can modify equations 11 and 12 as follows. Let Sc be defined as the sum of the signal component magnitudes in the original spectrum times the normalized HDF response. For a single DC input to the HDF Sc = 1. Let Sig be the sum of the compensated image magnitudes times the normalized HDF response. In the interpolate by 11 example $\mathrm{SIg} \cong 0.0005109$.

If $\mathrm{Sc}+\mathrm{Slg}$ is greater than 1 then
Data Shift =

$$
\begin{equation*}
75-\text { Ceiling }\left(\log _{2}\left(M_{1}{ }^{5}(S c+S \lg ) / L\right)\right) \tag{13}
\end{equation*}
$$

Scale Factor $=$

$$
\begin{equation*}
\mathrm{L}_{2}{ }^{\mathrm{CEILING}\left(\mathrm{LOG}_{2}\left(\mathrm{M}_{1}(\mathrm{SC}+\mathrm{SLG}) / \mathrm{L}\right)\right)} /(\mathrm{Sc}+\mathrm{SIg})_{1} \mathrm{M}_{1}^{5} \tag{14}
\end{equation*}
$$



FIGURE 9. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 16 CASE

Applying equations 13 and 14 would cause a negligeable loss in dynamic range.

The image power which is passed in the HDF will be removed in the subsequent FIR filter.

It can be observed from Figures 9 through 23 that for the HDF set to decimation by 16 near DC images are so greatly attenuated for interpolation by power of 2 cases that equations 11 and 12 can be used even for peak input conditions.

## Special Case 2 - Overflow Possibilities When the Interpolation Factor is Greater Than the HDF Decimation Factor

It is not recommended to use the DDC in a wideband application which requires an interpolation rate greater than the HDF decimation rate unless a loss in dynamic range can be tolerated. As a general rule a 6dB loss in dynamic range will result for every factor of 2 that the interpolation rate is greater than the decimation rate.

An example of the interpolation factor being greater than the HDF decimation factor is shown in Figure 24. In this example the interpolation factor is 32 and the HDF decimation factor is 16.

As seen in Figure 24 images can lie in the main lobe of the HDF filter curve as well as side lobes. In this case equations 13 and 14 are still applied with the exception that near DC image components in the HDF main lobe must be included in the SIg calculation. Further, the definition of near DC components is now dependent on the number of image components that can lie in the main lobe and the side lobes. The near DC "width" can be calculated by considering the slope of the HDF response curve in the area of the original spectrum and the total magnitude of the images. Since this is highly dependent on the interpolation rate in the case where the interpolation rate is greater than the HDF decimation rate, it is left to the user to derive.


FIGURE 10. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 15 CASE


FIGURE 11. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 14 CASE


FIGURE 13. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 12 CASE


OHz
$f$ 's $/ 2=10 \mathrm{fs} / 2=37.5 \mathrm{MHz}$
FIGURE 15. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 10 CASE


FIGURE 17. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 8 CASE


FIGURE 12. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 13 CASE


FIGURE 14. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 11 CASE


FIGURE 16. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 9 CASE


FIGURE 18. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 7 CASE


FIGURE 19. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 6 CASE


FIGURE 21. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 4 CASE


FIGURE 23. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 2 CASE

## Center Frequency Calculation

Decreasing the minimum decimation rate of the DDC by interpolation impacts the calculation and resolution of the local oscillator control words with the exception of Phase Offiset.

The Phase Generator in the DDC uses a 33 bit phase accumulator to generate an 18 bit phase word which controls the local oscillator [1]. In continuous carrier wave (CW) down convert mode the 32 bit Maximum Phase Increment is used to control the phase step between successive Phase Generator outputs. The Maximum Phase Increment represents phase increments from 0 to $\pi\left(1-2^{-32}\right)$ relative to the DDC input sampling rate. When the DDC is proceeded by a sam-


FIGURE 20. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 5 CASE


FIGURE 22. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 3 CASE


FIGURE 24. REPEATED INPUT SPECTRUM WITH THE HDF RESPONSE CURVE AND NEAR DC IMAGES SUPERIMPOSED FOR THE INTERPOLATE BY 32 CASE
ple rate expander the input sample rate is $1 / L$ times the DDC input sample rate. Therefore, the maximum valid phase step relative to the input sample rate is $1 / L$ that of the DDC. Likewise, the frequency resolution is reduced by $L$.

We now illustrate the afore stated points by way of example.
Assume a 4MSPS input and a desired decimation of 4. The DDC would be clocked at 64 MHz and would be preceded by a sample rate expander which up samples by a factor of 16. The HDF decimation rate would be set to 16.

The Maximum Phase Increment can be programmed from $\mathrm{O}_{\mathrm{H}}$ to $\mathrm{FFFFFFFF}_{\mathrm{H}}$ representing an LO frequency from DC to just under 32 MHz . However, the highest input frequency into


FIGURE 25. AN EXAMPLE SAMPLE RATE EXPANSION CIRCUIT WITH A MAXIMUM EXPANSION OF 8 AND A MAXIMUM CLOCK OF 65 MHz
the sample rate expander is 2 MHz which is in turn the highest valid LO frequency. This LO frequency corresponds to a Maximum Phase Increment value of FFFFFFFFF $_{H} / 16$ or FFFFFFFF $_{H}$.
If the DDC sampling rate were 4 MHZ the frequency resolution would be $4 \mathrm{MHz} / 2^{33}$. Since the DDC sampling rate is 64 MHz the frequency resolution is $64 \mathrm{MHz} / 2^{33}$, or $1 /$ th that of $4 \mathrm{MHz} / 2^{33}$.

In Chirp mode the Maximum Phase Increment, Minimum Phase Increment, and Delta Phase Increment must also be calculated for the input sample rate relative to the DDC sampling rate.

## Example Sample Rate Expander Circuit

Figure 25 shows an example sample rate expander circuit built around a high speed CMOS synchronous counter and four high speed CMOS quad dual port registers.

The synchronous counter is preset with 9 minus $L$, the desired interpolation rate. The count enable parallel (CEP), count enable trickle (CET), and synchronous reset (SR) inputs are tied high. For L-1 counts of the DDC clock the counter's Q3 output line is low and is used to select the grounded 11 inputs into the quad dual port registers. On the Lth count Q3 goes high, initiating two actions. First it selects the input data on the 10 inputs to the quad dual port registers. Second, it presets the counter. The high rate outputs of the quad dual port registers are connected to the DDC's data inputs. This action results in sample rate expansion by L . This circuit can be used for DDC clock rates up to approximately 65 MHz and interpolation rates of up to 8 . Additional ANDing logic can be attached to the counter outputs to increase the possible interpolation rates to 16.

Figure 26 shows a similar circuit using two PAL's.


FIGURE 26. AN EXAMPLE SAMPLE RATE EXPANSION CIRCUIT USING TWO PALS WITH A MAXIMUM EXPANSION OF 8 AND A MAXIMUM CLOCK OF 75MHz

The first PAL is configured as a counter and six AND gates with one input of each AND gate tied to a common control line coming from the counter and the other input connected to an input data line. The logical configuration of the first PAL is as follows.
DOX = DIx and $\overline{\mathrm{D}}$
$A=(D$ and $\bar{A})+(\bar{D}$ and INA)
$B=(D$ and $A$ and $\bar{B})+(\bar{D}$ and $I N B)+(D$ and $\bar{A}$ and $B)$
$C=(D$ and $A$ and $B$ and $\bar{C})+(\bar{D}$ and INC)

+ (D and $\overline{A \text { and } B}$ and $C$ )
$D=(\bar{A}$ and $B$ and $C$ and $D)+(\bar{D}$ and IND)
The other PAL is configured as ten AND gates with one input of each AND gate tied to a common control line coming from the counter via an input line and the other input connected to an input data line. Logically the second PAL is configured as follows.

DOx $=\operatorname{DIx}$ and $\overline{\mathrm{D}}$
All outputs are registered.
The operation of this circuit begins as the counter is preset with a value of 17 minus $L$, the interpolation factor $L$ can be up to 8 . On successive DDC clocks the counter counts up until it rolls over to zero. Until the roll over occurs $D$ is in a high state and thus $\overline{\mathrm{D}}$ is in a low state. Since $\overline{\mathrm{D}}$ is in a low state all data outputs are in a low state. This stuffs zeros between the low rate data input to the PALs.

When the counter rolls over $\overline{\mathrm{D}}$ goes high resulting in two actions. First the input data is passed through the AND gates and into the registered outputs to be passed to the DDC. Second, it reloads the counter to begin the count sequence anew.

This action results in sample rate expansion by L . This circuit can be used for DDC clock rates up to the maximum 75 MHz and interpolation rates of up to 8. Additional logic can be incorporated in the counter to increase the possible interpolation rates.

## Bibliography

[1] HSP50016 Data Sheet, Harris Semiconductor, Melbourne, FL, 1993.
[2] Crochiere, R.E. and Rabiner, L.R., Multirate Digital Signal Processing, Prentice-Hall, 1983.
[3] Hogenauer, E.B., "An Economical Class of Digital Filters for Decimation and Interpolation," IEEE Trans. on ASSP, Vol. ASSP-29, No. 2, pp. 155-162, April 1981.
[4] Riley, C.A., et. al., "High-Decimation Digital Filters," Proc. of ICASSP91, Vol. 3, pp. 1613-1616, Toronto, May, 1991.
[5] Chester, D.B, et. al., "VLSI Implementation of a Wide Band, High Dynamic Range Digital Drop Receiver," Proc. of ICASSP91, Vol. 3, pp. 1605-1608, Toronto, May, 1991.


## Harris Digital Signal Processing

## EXTENDED DIGITAL FILTER CONFIGURATIONS

## Introduction

Harris HSP43891, HSP43881and HSP43481 Digital Filters (DFs) perform high speed sum-of-products operations. These video speed devices operate at 30 MHz , offering substantial improvement in processing speed over other available technology. Throughputs in excess of 30 MHz are achieved using multiple devices.

The DF data sheet explains how multiple DFs can be easily cascaded to achieve long filters with 8 bit data and coefficients. This note presents extensions of the basic cascaded configuration for:

- Designing Extended Length Filters Using a Single Device (the Number of Taps Exceeds the Number of Cells).
- Implementing Higher Precision (Greater Than 8 or 9 Bits) Full Speed Designs Using Multiple Devices.
- Implementing Higher Precision Designs Using a Single Device.

It is assumed that the reader has a basic knowledge of filter design and some digital hardware experience. Readers who require more detailed information on the electrical characteristics of the DF family devices should refer to the Harris DF engineering data sheets. Harris also provides a comprehensive set of hardware and software development tools.

## The Finite Impulse Response Filter

The finite impulse response (FIR) filter is simply a finite-length sum-of-products digital filter. Each output sample is a
weighted sum of the new input value and the L-1 previous inputs, where $L$ is the order of the filter. With the tapped delay line architecture (Figure 1) the filter coefficients remain fixed while the input data shifts from cell to cell on each clock cycle.

The DF's architecture (Figure 2) is different from the traditional tapped delay line filter. In the DF the filter coefficients shift from cell to cell with each clock cycle. As each new data sample becomes available it is distributed to all of the cells at the same time. In addition, every DF cell contains its own multiplier and accumulator. This allows each cell to maintain an independent sum-of-products in its accumulator. A new output value becomes available on each clock cycle by properly sequencing the filter coefficients through the cells.


FIGURE 1. DIRECT FORM REPRESENTATION OF FIR FILTER


FIGURE 2. DF CELL DIAGRAM

Each cell's accumulator is cleared after its contents are output. This allows accumulation of the next sum-of-products to begin. Note that the filter coefficients enter from the left, shifting one cell to the right with each clock cycle.
A single device may be used to implement filters with a large number of coefficients. In this case the number of filter taps will exceed the number of DF cells. This requires manipulating the input data and filter coefficient sequences, maintaining the proper sum-of-products in each cell's accumulator. This implementation is described in greater detail in the following section.

## Eight Tap Filter With a Four Cell Device

A simple example is the best way to demonstrate how data and coefficients are properly sequenced. Table 1 illustrates the situation when an eight tap filter is computed in a single 4 cell HSP43481. The table lists information in six columns. The first column shows the initial 21 clock cycles, which is enough to evaluate the example. The next four columns represent the actions taking place in each of the four DF cells as a function of the clock. The final column shows the output results, also a function of the clock.

Within the filter cell are internal pipeline delays. The result is a startup delay of three CLKs before the data and coefficients present at the input of the DF are processed and stored in the accumulator of the first cell. This delay is not
relevant to the sequential operation of the DF and will be ignored in subsequent discussions (also ignored in Table 1).
The basic computational sequence is shown below:
CLK 0 - Initial data point $X_{0}$ is made available to all four cells. At the same time coefficient $C_{7}$ enters Cell 0.

- The First Product ( $C_{7} \times X_{0}$ ) is Computed and Stored in Accumulator of Cell 0.
CLK $1-X_{1}$ is made available to all four cells. At the same time coefficient $C_{6}$ enters Cell 0 , shifting $C_{7}$ to Cell 1.
- The Accumulator of Cell 0 is Updated With the Additional Term $\mathrm{C}_{6} \times \mathrm{X}_{1}$.
- The Product $C_{7} \times X_{1}$ is Computed and Stored in Accumulator of Cell 1.
CLK $2-X_{2}$ is made available to all four cells. At the same time coefficient $\mathrm{C}_{5}$ enters Cell 0 , shifting $\mathrm{C}_{7}$ to Cell 2 and $\mathrm{C}_{6}$ to Cell 1.
- The Accumulator of Cell 0 is Updated With the Additional Term $\mathrm{C}_{5} \times \mathrm{X}_{2}$.
- The Accumulator of Cell 1 is Updated With the Additional Term $\mathrm{C}_{6} \times \mathrm{X}_{2}$.
- The Product $C_{7} \times X_{2}$ is Computed and Stored in Accumulator of Cell 2.
- 

etc.

TABLE 1. HSP43481 8 TAP FIR FILTER SEQUENCE USING SINGLE 4 CELL DEVICE


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | $C_{7} \times{ }_{1}$ | 0 | 0 | - |
| 2 | $+C_{5} \times{ }^{2}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{5} \times{ }^{3}$ | $+\mathrm{C}_{6} \times \times 3$ | $C_{7} \times{ }^{\text {x }}$ | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{4}$ | - |
| 5 | $+C_{2} \times{ }_{5}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{5}$ | - |
| 6 | $+C_{1} \times x_{6}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{6}$ | $+c_{3} \times{ }_{6}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{6}$ | - |
| 7 | $+\mathrm{C}_{0} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{7}$ | Cell $\mathrm{O}\left(\mathrm{Y}_{7}\right)$ |
| 8 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | Cell $1\left(Y_{8}\right)$ |
| 9 | 0 | 0 | $+\mathrm{C}_{0} \times{ }^{\text {P }}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{9}$ | Cell 2 (Yg) |
| 10 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{10}$ | Cell $3\left(Y_{10}\right)$ |
| 11 | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | - |
| 12 | $+\mathrm{C}_{6} \times \mathrm{X}_{5}$ | $\mathrm{C}_{7} \times{ }^{\text {¢ }}$ | 0 | 0 | - |
| 13 | $+C_{5} \times X_{6}$ | $+C_{5} \times x_{0}$ | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ | 0 | - |
| 14 | $+\mathrm{C}_{4} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | - |
| 15 | $+\mathrm{C}_{3} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{8}$ | $+C_{6} \times x_{8}$ | - |
| 16 | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+C_{3} \times{ }^{\prime}$ | $+C_{4} \times{ }^{1}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{9}$ | - |
| 17 | $+C_{1} \times{ }_{10}$ | $+C_{2} \times{ }^{10}$ | $+c_{3} \times{ }_{10}$ | $+C_{4} \times{ }_{10}$ | - |
| 18 | $+\mathrm{C}_{0} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+C_{3} \times{ }_{11}$ | Cello ( $Y_{11}$ ) |
| 19 | 0 | $+\mathrm{C}_{0} \times{ }^{12}$ | $+c_{1} \times{ }_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell $1\left(Y_{12}\right)$ |
| 20 | 0 | 0 | $+C_{0} \times X_{13}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{13}$ | Cell $2\left(Y_{13}\right)$ |
| 21 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{14}$ | Cell $3\left(Y_{14}\right)$ |

This process continues until eight taps have been computed and accumulated in each cell. This happens first in Cell 0 , followed one CLK later by Cell 1, two CLKs later by Cell 2, and three CLKs later by Cell 3. Output points become available after each cell accumulates the sum of eight taps in the order given above.

After Cell 3's output becomes available, we are ready to begin work on the next four output points. We can cycle the eight filter coefficients in the same fashion as before but the input data is out of sequence. Before computing the fifth output point the DF requires $X_{4}$ to be available at the data input. Since $X_{4}$ passed by seven CLKs ago (during CLK 4) some method of storing the previous seven data points is necessary.

In order to access the previous seven data values they must have been originally stored in some form of sequential memory. FIFOs work very well and will be discussed in the next section. Starting with CLK 11 the taps once more begin to accumulate in each of the four cells.

The result of re-accessing data after every four output points is to lower the effective throughput. The output rate drops about fifty percent to a rate of four output points for every eleven CLKs.

## L Tap Filter With an N Cell Device Where L>N

The example above leads to the more general case of implementing an $L$ tap filter with an $N$ cell device ( $L>N$ ). When an $L$ tap filter is implemented using an $N$ cell DF (where $L>N$ ), the DF computes a block of N filter output samples at a time. Between these output blocks there are L-1 CLK cycles during which no valid output points are available. Therefore, generating a block of N output points requires $\mathrm{L}+\mathrm{N}-1$ CLKs. During these $L+N-1$ CLKs there are $L+N-1$ new input samples being clocked into the DIN (Data IN) port.

It can be seen from Table 1 that N outputs are read out of the DF during the last $N$ CLKs of each $L+N-1$ CLK sequence. After inputting the first $L$ data samples $\mathrm{N}-1$ CLKs are required to flush the coefficients from the cells. The final L-1 of the previous $L+N-1$ input samples must be re-submitted at the input port. After the outputs are read out an additional $L+N-1$ samples are fed in and the process repeats itself until no more data is available.

In this paper, throughput is defined as the average rate at which outputs are computed by the DF. When the number of taps exceeds the number of filter cells, the necessity to re-access the data stream determines the maximum throughput. The generalized performance of an $L$ tap, $8 \times 8$ FIR filter is shown below. Let:
$\mathrm{L}=$ Number of taps
$\mathrm{N}=$ Number of filter cells in DF
$R=$ Maximum clock rate of DF $(20,25.6$, or 30 MHz$)$
$F_{S}=$ Desired throughput (MHz) where $R>F_{S}$

If $L, N$, and $R$ are known then:
$F_{S}=N \times R /(L+N-1)$
If $L, R$, and $F_{S}$ are known then:
$N=F_{S}(L-1) /\left(R-F_{S}\right)$
Since there are either four (HSP43481) or eight (HSP43881) cells in each DF, the required number of DFs can be computed as:
\# of 4 cell DFs $=\mathrm{N} / 4$ (round up to next integer value)
\# of 8 cell DFs $=\mathrm{N} / 8$ (round up to next integer value)
An example design with $L=128$ taps, $F_{S}=5 \mathrm{MHz}$, and
$\mathrm{R}=20 \mathrm{MHz}$ would yield:
$\mathrm{N}=5 \times 127 / 15=43$ cells
\# of 4 cell DFs $=43 / 4=11$
\# of 8 cell DFs $=43 / 8=6$
Optimum arrangement $=40 / 8+3 / 4=$ Five 8 cell and one 4 cell DFs.

The sequencing of the input data can be realized in various ways, with the simplest design using FIFOs. Figure 3 shows the block diagram of a design using an eight cell DF. The input data buffered in two FIFOs (each must have threestate outputs).

An 8 bit counter is configured to count modulo $L+N-1$. To initialize the system, the first L-1 data samples are passed through FIFO \#1 and written into FIFO \#2. While this occurs N more samples are clocked into FIFO \#1. Following that a repetitive steady state sequence begins as shown below:

1. Clock the first L-1 samples from FIFO \#2 into the DF.
2. Clock $N$ samples from FIFO \#1 into the DF.
3. Clock the last L-1 samples of the sequence in steps 1 and 2 back into FIFO \#2.
4. Clock the next N samples into FIFO \#1 concurrently with steps 1-3.

This sequence of steps 1 through 4 can be repeated ad infinitum.

The output data is available in blocks of $N$ points separated by L-1 CLK cycles. FIFO \#3 acts as a rate buffer for the output and is optional. The coefficient memory contains the L coefficients followed by the necessary $\mathrm{N}-1$ zeros.

A design example using the above technique might include a 57 tap filter with a sample rate of 2.5 MHz . This can be done with a single 8 cell device operating at 20 MHz .

## Higher Precision Filters and Correlators

Several digital filtering applications require wider wordwidth calculations to maintain precision. The DFs are designed to be flexible in creating filters with input precision levels of 8 , $16,24,32$ bits or greater.
The first step is to restructure the data and/or coefficients into 8 bit quantities which can be processed by the DF.


FIGURE 3. BLOCK DIAGRAM OF AN 8 CELL DF CONFIGURED TO IMPLEMENT EXTENDED FILTER LENGTHS (UP TO 249 TAPS)

These quantities are used to form the partial products of the larger multiplication involving the full precision data and coefficients. An example of segmenting the partial products of a $16 \times 8$ multiplication ( 16 bit coefficients and 8 bit data) would be:
$C(16$ bit $)=C_{H} \times 2^{8}+C_{L} \times 2^{0}$
$X(8 \mathrm{bit})=X \times 20$

$$
\begin{aligned}
& H=\text { High Order Byte } \\
& L=\text { Low Order Byte }
\end{aligned}
$$

Consequently,
$C \times X=\left(C_{H} \times 2^{8}+C_{L} \times 2^{0}\right) \mathrm{X} \times 2^{0}$

$$
=C_{H} \times \times 2^{8}+C_{L} \times 2^{0}
$$

The process of convolution or correlation requires repeated multiply and accumulate operations. The resulting partial output word widths are a function of the number of MAC operations and of the coefficient scaling. Although each partial product is only 16 bits wide, the sum of the partial products in the output stage is allowed to accumulate up to a maximum width of 26 bits.

Care must be taken when combining the upper and lower partial sums-of-products into each complete output result. Figure 5 illustrates how the upper and lower sums of partial products for each output point must be re-combined. Sign extension must be used if more than 26 bits are required from the output stage representing the least significant sum of partial products.

Two separate techniques can be used in determining higher precision results:

1. Use separate DFs, combining the two partial products using external adders.

- Throughput equals the clock rate of the DF.

2. Accumulate the two partial products in separate cells of a single $D F$.

- The SHADD (SHift and ADD) feature of the output adder allows the data to be properly aligned and combined.
- Throughput is determined by the number of taps, partial products, and DF cells, as well as the clock rate of the DF.

The equations describing the filtering operation are the same for either technique and can be given as:

$$
y(n)=\sum_{i=0}^{N-1} C(i) X(n-i)
$$

However: $\left(C_{H} \times 2^{8}+C_{L}\right) X=C_{H} X \times 2^{8}+C_{L} X$
Therefore: $y(n)=\sum_{i=0}^{N-1} C_{H}(i) X(n-i) \times 2^{8}+\sum_{i=0}^{N-1} C_{L}(i) \times(n-1)$
Assuming the coefficients are represented as two's complement numbers, the least significant byte has to be treated as a positive (unsigned) number. The TCCI input of the DF is used to take care of this.

## Word-Size Extension at Full Speed

Full performance filters with extended precision data and/or coefficients are easily designed. This is achieved by computing the partial products in separate DFs and combining their results with external adders. When external adders are used the system performance is limited only by the throughput of the DF itself.
The filter equations listed directly above can be expanded into their partial products and grouped for processing. An
expansion of the first four output points resulting from the convolution of 16 bit coefficient and 8 bit data is shown in Table 2.
In this case, for a 4 tap filter, each device accumulates four partial products at once, one in each cell. The output adder combines these partial products into the proper result. The sequence table (Table 2) shows the results of the multiply accumulate operations for one device (DFO).

Figure 4 is a block diagram that directly implements the grouping given above. DFO is generating the $C_{L} X$ partial products while DF1 is generating the partial products for $\mathrm{C}_{\mathrm{H}} \mathrm{X}$. The two $8 \times 8$ partial products are generated in separate DFs and combined with an external adder. Notice that the lower and upper coefficients bytes are separated and used to supply different DFs. Using this design the throughput is limited only by the DF (up to 30 MHz ).

The adder stage of Figure 4 merits further discussion. Each 4 cell DF has 26 output lines (SUMO-25). Therefore, if all the available bits were preserved we would have a 34 bit sum as shown in Figure 5. However, many designs require only 16 output bits. Which 16 bits are selected depends on the coefficient scaling and the input signal level.

TABLE 2. HSP43481 4 TAP SINGLE PARTIAL PRODUCT FIR FILTER

$$
\begin{aligned}
& y(0)=C_{H}(0) X(0) \times 2^{8}+C_{L}(0) X(0) \\
& +C_{H}(1) \times(1) \times 2^{8}+C_{L}(1) X(1) \\
& +\mathrm{C}_{\mathrm{H}}(2) \mathrm{X}(2) \times 2^{8}+\mathrm{CL}_{\mathrm{L}} \\
& \text { (2) } \mathrm{X}(2) \\
& +\mathrm{C}_{\mathrm{H}}(3) \times(3) \times 2^{8}+\mathrm{C}_{L} \\
& \text { (3) } \times(3) \\
& \xrightarrow[\substack{\text { DF1 } \\
\text { Cell O }}]{\longrightarrow} \mid
\end{aligned}
$$

$$
\begin{aligned}
& y(2)=C_{H}(0) X(2) \times 2^{8}+C_{L}(0) \times(2) \\
&+C_{H}(1) \times(3) \times 2^{8}+C_{L}(1) \times(3) \\
&+C_{H}(2) \times(4) \times 2^{8}+C_{L}(2) \times(4) \\
&+C_{H}(3) \times(5) \times 2^{8}+C_{L}(3) \times(5) \\
& \xrightarrow[\text { DF } 1]{ } \\
& \text { Cell } 2
\end{aligned}
$$

$$
\begin{aligned}
& y(1)=C_{H}(0) X(1) \times 2^{8}+C_{L}(0) X(1) \\
&+C_{H(1) X(2) \times 2^{8}+C_{L}(1) \times(2)} \\
&+C_{H(2) X(3) \times 2^{8}+C_{L}(2) X(3)} \\
&+C_{H(3) X(4) \times 2^{8}+C_{L}(3) X(4)} \\
& \text { DF1 } \\
& \text { Cell } 1
\end{aligned}
$$

$$
\begin{aligned}
& y(3)=C_{H}(0) X(3) \times 2^{8}+C_{L}(0) X(3) \\
&+C_{H(1) X(4) \times 2^{8}+C_{L}(1) X(4)}^{C_{H}} \\
&+C_{H}(2) X(5) \times 2^{8}+C_{L}(2) X(5) \\
&+C_{H(3) X(6) \times 2^{8}}^{C_{L}}+C_{\text {DF1 }}^{C(3) X(6)} \\
& \text { Cell } 3
\end{aligned}
$$

:
etc.

| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {LO }}$ | 0 | 0 | 0 |  |
| 1 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 1}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {L1 }}$ | 0 | 0 |  |
| 2 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{\mathrm{L} 2}$ | $+C_{L 2} \times{ }_{\text {L }}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {L3 }}$ | 0 |  |
| 3 | $+\mathrm{CLO}_{\text {O }} \times \mathrm{X}_{\text {L3 }}$ | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{\mathrm{L} 3}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\text {L3 }}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {L3 }}$ | Cello (YL3) |
| 4 | $\mathrm{CLL3} \times \mathrm{X}_{\mathrm{L} 4}$ | $+_{\text {CLO }} \times \mathrm{X}_{\text {L4 }}$ | $+C_{L 1} \times{ }_{\text {L4 }}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 4}$ | Cell $0\left(Y_{L} 4\right)$ |
| 5 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 5}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {L5 }}$ | $+\mathrm{C}_{\mathrm{LO}} \times \mathrm{X}_{\mathrm{L} 5}$ | $+C_{L 1} \times \times_{L 5}$ | Cell $0\left(Y_{L} 5\right)$ |
| 6 | $+\mathrm{C}_{L 1} \times \mathrm{X}_{\text {L6 }}$ | $+\mathrm{CLL} \times \mathrm{X}_{\text {L6 }}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\mathrm{L} 6}$ | $+\mathrm{C}_{\text {LO }} \times \mathrm{X}_{\text {L6 }}$ | Cell $0\left(Y_{L} 6\right)$ |
| 7 | $+\mathrm{C}_{\mathrm{LO}} \times \mathrm{X}_{\mathrm{L7}}$ | $+C_{L 1} \times X_{L 7}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 7}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\mathrm{L} 7}$ | Cello ( $\mathrm{Y}_{\mathrm{L}}$ ) |



FIGURE 4. BLOCK DIAGRAM OF A $30 \mathrm{MHz}, 4$ TAP, $16 \times 8$ FIR FILTER


FIGURE 5. IDEAL OUTPUT STAGE ADDER

The results for the $16 \times 8$ example can be extended to the general case of more than four taps. Let:
$\mathrm{L}=$ Number of taps
$N=$ Total number of filter cells required
$R=$ Maximum clock rate of $\operatorname{DF}(20,25.6$, or 30 MHz$)$
$\mathrm{F}_{\mathrm{s}}=$ Desired throughput ( MHz )
For a full speed ( $F_{S}=R$ ) $16 \times 8$ design: $N=2 L$
There are either four (HSP43481) or eight (HSP43881) cells in each DF. Therefore, the number of DFs can be computed as: \# of 4 cell DFs $=2 \times$ [L/4 (rounded up to next integer value)] \# of 8 cell DFs $=2 \times[L / 8$ (rounded up to next integer value)]
An example design with $L=15$ taps and $F_{S}=R=25 \mathrm{MHz}$ would yield:
\# of 4 cell DFs $=2 \times[15 / 4]=8$
\# of 8 cell DFs $=2 \times[15 / 8]=4$

## Word-Size Extension Using One Device

The second technique for extending the word width accumulates the partial products in separate cells of a
single device. An expansion of the first four output points resulting from the convolution of 16 bit coefficient and 8 bit data is shown below.
The groupings are the same as in the earlier case using multiple DFs. However, in this case individual cells within one DF are responsible for generating the partial products. This method of processing eliminates the need for an external adder in exchange for lower throughput.
The sequence table (Table 3) shows the results of the multiply accumulate operation for the separate cells of a 4 tap $16 \times 8$ FIR filter. Cells 1 and 3 accumulate the partial products $\mathrm{C}_{\mathrm{H}} \mathrm{X}$. Cells 0 and 2 accumulate the partial products $C_{L} X$.

After computing and outputting the first result Cell 0 is ready to accumulate the next partial products. At this point (CLK 11) Cell 0 needs to re-access $X_{2}$, which was last available during CLK 5. In order to accomplish this a temporary storage, sequential memory (such as a FIFO) is necessary. The design of Figure 6 shows such a FIFO based design.


TABLE 3. HSP43481 4 TAP, $16 \times 8$ FIR FILTER SEQUENCE
INPUT DATA
SEQUENCE
COEFFICIENT
SEQUENCE $\mathrm{C}_{\mathrm{L}}, \mathrm{C}_{\mathrm{H} 3}, 0,0, \mathrm{C}_{\mathrm{LO}}, \mathrm{C}_{\mathrm{HO}}, \mathrm{C}_{\mathrm{L} 1}, \mathrm{C}_{\mathrm{H} 1}, \mathrm{C}_{\mathrm{L} 2}, \mathrm{C}_{\mathrm{H} 2}, \mathrm{C}_{\mathrm{L} 3}, \mathrm{C}_{\mathrm{H} 3} \longrightarrow \longrightarrow \mathrm{Y}, \ldots, \mathrm{x}_{4}, \mathrm{x}_{6}, \ldots, \mathrm{x}_{2}, \mathrm{x}_{4}, \mathrm{x}_{3}, \mathrm{x}_{2}, \mathrm{x}_{1}, \mathrm{x}_{0} \rightarrow \mathrm{Y}, \ldots \mathrm{Y}(3) \ldots$

| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{CH3} \times 0$ | - | - | - | - |
| 1 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{0}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{0}$ | - | - | - |
| 2 | $\mathrm{CH}_{\mathrm{H} 2} \times 0$ | $\mathrm{CL} \times 0$ | $\mathrm{CH}_{3} \times 0$ | - | - |
| 3 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{1}$ | $+\mathrm{CH}_{2} \times \mathrm{X}_{1}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{1}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{1}$ | - |
| 4 | $\mathrm{CH1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{CH}_{2} \times 0$ | $\mathrm{CLS} \times 0$ | - |
| 5 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{2}$ | $+\mathrm{CH}_{\mathrm{H} 1} \times \mathrm{X}_{2}$ | $+\mathrm{CL}_{2} \times \mathrm{X}_{2}$ | $+\mathrm{CH}_{2} \times \mathrm{X}_{2}$ | - |
| 6 | $\mathrm{CHO}^{\text {O }}$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | $\mathrm{CH}_{1} \times 0$ | $\mathrm{CL2}^{1} \mathrm{O}$ | - |
| 7 | $+\mathrm{CLO} \times \mathrm{X}_{3}$ | $+\mathrm{CHO}_{\mathrm{HO}} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{\mathrm{L1}} \times \times_{3}$ | $+\mathrm{CH}_{\mathrm{H} 1} \times \mathrm{X}_{3}$ | YL(3) |
| 8 | $0 \times 0$ | $\mathrm{CLO}^{1} \mathrm{O}$ | $\mathrm{CHO} \times 0$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | - |
| 9 | $0 \times \mathrm{X}_{4}$ | $0 \times \times 4$ | $+\mathrm{CLO} \times \mathrm{X}_{4}$ | $+\mathrm{CHO} \times \mathrm{X}_{4}$ | $\mathrm{Y}_{\mathrm{H}}(3)$ |
| 10 | $\mathrm{CH}_{3} \times 0$ | $0 \times 0$ | $0 \times 0$ | $\mathrm{CLO} \times 0$ | - |
| 11 | $\mathrm{CL3} \times \mathrm{X}_{2}$ | $\mathrm{CH}_{\mathrm{H} 3} \times \mathrm{X}_{2}$ | $0 \times{ }_{2}$ | $0 \times 12$ | $Y_{L}(4)$ |
| 12 | $\mathrm{CH}_{2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | $\mathrm{CH}_{\mathrm{H}} \times 0$ | $0 \times 0$ | - |
| 13 | $+\mathrm{CL}_{2} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{\mathrm{H} 2} \times \mathrm{X}_{3}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{3}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{3}$ | $\mathrm{Y}_{\mathrm{H}}(4)$ |
| 14 | $\mathrm{CH}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{CH}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | - |
| 15 | $+\mathrm{C}_{\mathrm{L1}} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{H} 2} \times \mathrm{X}_{4}$ | - |
| 16 | $\mathrm{CHO}_{\mathrm{HO}} \times$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | $\mathrm{CH}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | - |
| 17 | + $\mathrm{CLO} \times \mathrm{X}_{5}$ | $+\mathrm{CHO}_{\mathrm{HO}} \times \mathrm{X}_{5}$ | $+C_{L 1} \times X_{5}$ | $+\mathrm{CH}_{1} \times \mathrm{X}_{5}$ | $Y_{L}(5)$ |
| 18 | $0 \times 0$ | $\mathrm{CLO} \times 0$ | $\mathrm{CHO} \times 0$ | $\mathrm{CLI}_{1} \times 0$ | - |
| 19 | $0 \times \times 6$ | $0 \times \times 6$ | $+\mathrm{CLO} \times \mathrm{X}_{6}$ | $+\mathrm{CHO}_{\mathrm{HO}} \times \mathrm{X}_{6}$ | $Y_{H}(5)$ |
| 20 | $\mathrm{CH}_{3} \times 0$ | $0 \times 0$ | $0 \times 0$ | CLO $\times 0$ | - |
| 21 | $\mathrm{CL} \times \times{ }_{4}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{4}$ | $0 \times{ }_{4}$ | $0 \times 14$ | $Y_{L}(6)$ |
| 22 | $\mathrm{CH}_{2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | $\mathrm{CH}_{3} \times 0$ | $0 \times 0$ | - |
| 23 | $+\mathrm{CL}_{2} \times \mathrm{X}_{5}$ | $+\mathrm{CH}_{2} \times \mathrm{X}_{5}$ | $\mathrm{CL3} \times \mathrm{X}_{5}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{5}$ | $\mathrm{Y}_{\mathrm{H}}{ }^{(6)}$ |
| 24 | $\mathrm{CH}_{1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{CH}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | - |
| 25 | $+\mathrm{CL}_{\mathrm{L} 1} \times \mathrm{X}_{6}$ | $+\mathrm{CH}_{\mathrm{H} 1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{6}$ | $+\mathrm{CH}_{\mathrm{H} 2} \times \mathrm{X}_{6}$ | - |



FIGURE 6. $16 \times 84$ TAP FIR FILTER BLOCK DIAGRAM

In order to interface the necessary zeros between data samples we must toggle the DIENB control line. This line is driven low when passing a valid data sample to the X register and set high when loading the $X$ register with zero. The sequencing of the input data through the FIFOs is similar to the example given in Figure 3.

The output stage (Figure 7) plays a key role in determining the final results. In the output stage there are several control signals. The most important signals controlling the output stage are SHADD (SHift and ADD), ADRO-1 (cell AdDRess), SENBL (Sum0-15 ENaBled), and SENBH (Sum16-25 ENaBled). SENBL and SENBH are always asserted in this example, enabling the three-state output buffer and allowing the external register to clock in data at the proper time. SHADD and ADRO-1 are used to control the flow of data through the output stage.

The contents of a selected cell (ADRO-1) are routed to two separate locations within the output stage; the 26 bit adder and the output mux. From the output mux the 26 bit cell
contents are available to the outside world as either the 16 LSBs (SENBL), 10 MSBs (SENBH), or all 26 bits (SENBL $+\overline{\text { SENBH }}$ ).

The 26 bit adder feeding the output buffer has two possible inputs. The first input represents the contents of the selected cell. The zero mux determines whether the other input to the adder is zero or the 18 MSBs of the output buffer. A high on the SHADD input selects the 18 MSBs of the output buffer and a low on the SHADD input selects zero. The results from the adder are immediately stored in the output buffer.

Data reaches the three-state buffer by one of two separate paths. The first path routes the data directly from the cell result multiplexer through the output multiplexer and onto the output bus. The second path is from the cell result multiplexer, through the adder, and finally onto the output bus. Both of these routes will be used in order to create the final result from the partial products.


FIGURE 7. DF OUTPUT STAGE

After the partial products are made available to the output bus they are stored in temporary registers. This allows the two sections of the final result to be combined properly. Following this the full result may be stored directly into some form of memory. Figure 6 shows a block diagram illustrating the complete concept.

The following summary describes the sequence of events listed in Table 3 (also refer to Figures 6 and 7).

CLK 0-5

- Each Cell Is Accumulating Partial Product Data
- SHADD Not Asserted

CLK 6

- Cell 0 Selected (ADRO-1 = 0)
- Erase Accumulator of Cell 0 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted


## CLK 7

- Cell 0 Contents Added to Zero and Available at Input to Output Buffer
- Cell 0 Contents Available at SUMO-15
- Cell 1 Selected (ADRO-1 = 1)
- Erase Accumulator of Cell 1 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted


## CLK 8

- External 8 Bit Register Clock Asserted. Lower 8 Bits of SUMO-15 (Least Significant Byte of $\mathrm{Y}(3)$ ) Entered Into External 8 Bit Register
- Cell 0 Contents Entered Into Output Buffer
- Cell 1 Contents Added to Zero and Available at Input to Output Buffer
- SHADD Asserted


## CLK 9

- Shift Cell 0 Contents Down 8 Bits and Add to Contents of Cell 1 (Output Buffer). This 16 Bit Value Becomes Available at SUMO-15
- SHADD Not Asserted

CLK 10

- External 16 Bit Register Clock Asserted. All 16 Bits of SUMO-15 (Most Significant Word of Y(3)) Entered Into External 16 Bit Register
- Cell 2 Selected (ADRO-1 =2)
- Erase Accumulator of Cell 2 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted


## CLK 11

- Cell 2 Contents Added to Zero and Available at Input to Output Buffer
- Cell 2 Contents Available at SUMO-15
- Cell 3 Selected (ADRO-1 = 3)
- Erase Accumulator of Cell $3(\overline{\text { ERASE }}=0)$
- Write Y(3) Into Output FIFO (Optional)
- SHADD Not Asserted


## CLK 12

- External 8 Bit Register Clock Asserted. Lower 8 Bits of SUMO-15 (Least Significant Byte of Y(4)) Entered Into External 8 Bit Register
- Cell 2 Contents Entered Into Output Buffer
- Cell 3 Contents Added to Zero and Available at Input to Output Buffer
- SHADD Asserted


## CLK 13

- Shift Cell 2 Contents Down 8 Bits and Add to Contents of Cell 3 (Output Buffer). This 16 Bit Value Becomes Available at SUMO-15
- SHADD Not Asserted

CLK 14

- External 16 Bit Register Clock Asserted. All 16 Bits of SUMO-15 (Most Significant Word of Y(4)) Entered Into External 16 Bit Register
- SHADD Not Asserted

This same pattern repeats until the input data is exhausted. Note that the value stored in the External Register must be stored elsewhere before the low byte of the next output value is sequenced.
The performance specifications for the $16 \times 8$ filter are listed below.

$$
\begin{aligned}
\text { - } 2 \text { Outputs/10 CLKS }=1 \text { Output/5.0 CLKS } \\
=200 \mathrm{~ns} / \text { Output ( } 25.6 \mathrm{MHz} \text { Device) } \\
=5 \mathrm{MHz} \text { Throughput ( } 25.6 \mathrm{MHz} \text { Device) }
\end{aligned}
$$

The results for the $16 \times 8$ design used in this implementation can be extended to the general case. Let:
$L=$ Number of taps
$\mathrm{F}_{\mathrm{S}}=$ Sample rate $(\mathrm{MHz})$
$\mathrm{N} 2=$ Number of 2 cell groups
$R=$ Maximum clock rate of $\operatorname{DF}(20,25.6$, or 30 MHz$)$
( $\mathrm{R}>\mathrm{F}_{\mathrm{S}}$ )
Then: $\quad F_{S}=(N 2 \times R) /(2 L+2(N 2-1))$
$\left.N 2=2 F_{s}(L-1) / R-2 F_{s}\right)$

# TIMING RELATIONSHIPS FOR HSP45240 

Author: Mike Petrowski

The timing diagram in Figure 1 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is programmed for One-Shot Mode with Restart (see Sequence Generator Section of Datasheet). In this example, the HSP45240 is configured to generate a sequence consisting of two address blocks. Each block is 6 addresses long, and the end of a block is denoted by the assertion of BLOCKDONE\#. As the final address in the second block is generated, both DONE\# and BLOCKDONE\# are asserted to signal the end of the address sequence. On the next clock, a new address sequence is started (see assertion of ADDVAL\#) because the Sequencer was configured to restart. In this mode the STARTOUT\# signal is asserted prior to the end of the address sequence for the synchronization of multiple HSP45240's.


NOTE: Asserting STARTIN\# after an addressing sequence has been started will cause the sequencer to restart from the beginning of the sequence.
FIGURE 1. SIGNAL RELATIONSHIPS FOR ONE-SHOT MODE WITH RESTART

The timing diagram in Figure 2 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is programmed for One-Shot Mode without Restart (see Sequence Generator Section of Datasheet). As in the above example, the HSP45240 is configured to generate a sequence consisting of two address blocks. Each block is 6 addresses long, and the end of a block is denoted by the assertion of BLOCKDONE\#. As
the final address in the second block is generated, both DONE\# and BLOCKDONE\# are asserted and addressing is halted.


FIGURE 2. SIGNAL RELATIONSHIPS FOR ONE-SHOT MODE WITHOUT RESTART

The timing diagram in Figure 3 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is internally started by writing the Sequencer "START" address (see Table 1 of Datasheet). The output signals are shown with respect to the rising edge of WR\# responsible for the internal START. The address generation parameters are as above.


FIGURE 3. SIGNAL RELATIONSHIPS FOR INTERNALLY GENERATED START

## DLYBLK Operation

Address generation can be halted by assertion of DLYBLK prior to the completion of an address block (Figure $4 \& 5$ ). Addressing will resume once DLYBLK is de-asserted. Since there is a pipeline delay between the assertion of DLYBLK at the pin and when it is internally active, DLYBLK must be asserted prior to the end of an address block. The pipeline delay associated with DLYBLK differs for halting address generation in mid-sequence and halting address generation after the final address block of a sequence.

For halting address generation in mid-sequence, DLYBLK must be asserted 3 clocks prior to the end of the addressing block as shown in Figure 4. In this example, DLYBLK is asserted for one clock cycle which delays the generation of the next address block by one clock. If addressing has been halted in mid-sequence, addressing will resume 4 clocks after de-asserting DLYBLK. Note: BLOCKDONE\# will be asserted and OUTO-23 will be held until addressing resumes.


## FIGURE 4. SIGNAL RELATIONSHIPS FOR A ONE CYCLE BLOCK DELAY IN MID-SEQUENCE

For halting address generation after the final block of addresses in a sequence, DLYBLK must be asserted 4 clocks prior to the end of the addressing block as shown in Figure 5. In this example, DLYBLK is asserted for one clock cycle which delays the start of a new address sequence by one clock. The part is assumed to be configured for One-Shot Mode with Restart. Addressing will resume 5 clocks after de-asserting DLYBLK. Note: BLOCKDONE\# and DONE\# will be asserted and OUTO-23 will be held until addressing resumes. Also, STARTOUT\# will be asserted one clock after the assertion of DLYBLK.


FIGURE 5. SIGNAL RELATIONSHIPS FOR A ONE CYCLE BLOCK DELAY AFTER FINAL BLOCK IN AN ADDRESSING SEQUENCE

## STARTIN\# Operation

The STARTIN\# pin has two functions: first, it downloads the configuration data in the processor interface into the register bank that controls the operation of the part; second, it starts the address sequence using the updated configuration. When STARTIN\# is deasserted, the part continues on with the new sequence. Note that there are four stages of pipeline delay between the sequence generator and the output of the part; all of the output signals will continue on using the original sequence for those four clock cycles.

After the assertion of STARTIN\#, the first value in the sequence appears on the output after four pipeline delays. The part will remain in this state for the remainder of the time that STARTIN\# is low, and for four clocks after STARTIN\# returns high. This is shown in Figure 6, note that the old sequence ends at clock 3; the first address of the new sequence goes from clock 4 to clock 12; the second address of the new sequence appears on clock 13.

Asserting STARTIN\# in the middle of a sequence demonstrates the sequence restart function as described above. The internal count of the HSP45240 returns to the starting point (the value in the Start Address Register - not the Current Block Start Address Register) on the first rising edge of CLK that STARTIN\# is low. The first address of the sequence is output four clocks after the assertion of STARTIN\#. The Sequencer goes to the second address in the sequence when STARTIN\# goes away; this address appears on the output pins four clocks later. Sequencing continues based on the updated configuration. In Figure 7, the new sequence is started on clock 1 ; the old sequence will continue unaffected until clock 4, and the first address of the new sequence becomes valid on the outputs during clock 5.


FIGURE 6. INPUT, OUTPUT SIGNALS WHEN STARTIN\# IS LONGER THAN ONE CLOCK CYCLE.




FIGURE 7. USING STARTIN\# TO RESTART SEQUENCE DURING OPERATION

# NOISE ASPECTS OF APPLYING ADVANCED CMOS SEMICONDUCTORS 

By: R. Kenneth Keenan, Ph.D. and David F. Bennett

## Introduction and Summary

This report is about noise aspects of high-speed logic, with a focus on Advanced CMOS semiconductor applications. The present report pertains to suppression of ringing for both short and long traces, with experimental evidence provided for long traces.

Although termination and decoupling techniques cited here minimize ringing for all semiconductor technologies (AC/ ACT, LSTTL, HCMOS, AS, etc.), external resistive termination is usually not required for slower semiconductor technologies. Decoupling is an important aspect of design for all semiconductor technologies.

The preferred termination technique is a resistor, $\mathbf{R}_{\mathrm{T}}$, equal in value to the trace's characteristic impedance, $Z_{0}$, in series with a trace at the driving end of that trace. For AC/ ACT, series termination results in a modest (1ns to 3 ns ) increase in propagation and transition times. The increase in transition times incurred with series termination helps to minimize interference generation.

The length of traces with distributed loading to which series termination can be applied is limited by the increased transition times at intermediate points along those traces.

For long traces with distributed loading, AC shunt termina-tion-a resistor in series with a small-value capacitor-is used from a trace to ground at the receiving end of a trace. The value of the capacitor depends on clock frequency, but it is typically 50 pF to 200pF. Larger values result in improved pulse fidelity at the expense of increased power dissipation in the terminating resistor. At the expense of a capacitor, AC shunt termination consumes much less power than purely resistive shunt termination. AC shunt termination does not appear to materially effect propagation and transition times, except insofar as it removes the ringing contributing to shorter transition and propagation times.

## Series Termination with a Single Receiver

## Resistive Termination

Figure 1 illustrates the waveforms at the receiver for the case of no termination and for the case where the line is terminated at the driver end of the line. The termination resistor is $80 \Omega$ approximately equal to the $78 \Omega$ characteristic impedance of the line on the board. In this and all succeeding Figures, the line is 12 inches long.


FIGURE 1. UNTERMINATED AND TERMINATED ( $\mathbf{R}_{\mathrm{T}} \approx \mathbf{Z}_{\mathrm{O}}$ ) LINES
This work was supported by Harris Semiconductor (Harris ) and The Keenan Corporation (TKC). The authors thank the external reviewers, Mr. Richard E. Funk, Manager, Applications Engineering, Harris Semiconductor, and Dr. Leonard Rosi, EMC Engineer, of Hewlett-Packard's Corvallis Workstation Operation, for their helpful comments.

[^8]Zero and five-volt reference lines are shown in each of the above oscillograms. It is clear from Figure 1 that termination assists in reducing both the undershoot for the low-to-high transition and the overshoot for the high-to-low transition. The noise immunity limits for CMOS are given in Table 1.

TABLE 1. NOISE IMMUNITIES AND MARGINS

| D.C. SPECIFICATION | VOLTAGE LEVEL <br> $(\mathrm{V})$ |
| :--- | :---: |
| Maximum Low-Level Input Voltage (Max $\left.\mathrm{V}_{\mathrm{IL}}\right)$ | 0.8 |
| Minimum High-Level Input Voltage $\left(\mathrm{Min} \mathrm{V}_{\mathrm{IH}}\right)$ | 2.0 |
| Maximum Low-Level Output <br> Voltage (Max $\left.\mathrm{V}_{\mathrm{OL}}\right)$ | 0.4 |
| Minimum High-Level Output <br> Voitage $\left(\right.$ Min $\left.\mathrm{V}_{\mathrm{OH}}\right)$ | 2.4 |
| Low-Level Noise Margin $\left(\mathrm{V}_{\mathrm{NML}}=\mathrm{V}_{\mathrm{IL}}-\mathrm{V}_{\mathrm{OL}}\right)$ | 0.4 |
| High-Level <br> $\left(\mathrm{V}_{\mathrm{NMH}}=\mathrm{V}_{\mathrm{OH}}-\mathrm{V}_{\mathrm{IH}}\right)$ | 0.4 |

For the unterminated line in Figure 1, the maximum $\mathrm{V}_{\text {IL }} 0.8 \mathrm{~V}$ is breached. Therefore, CMOS gates driven with the unterminated-line (upper) waveform in Figure 1 can mistake the "bump" between $\mathrm{t}=20 \mathrm{~ns}$ and $\mathrm{t}=30 \mathrm{~ns}$ for a "high". Thus, for the unterminated-line waveform, CMOS gates are subject to logic errors. The terminated line rings less and provides a signal which is well within the noise immunity limits for AC/ACT.

The relative sensitivity of the value of termination resistor was assesed. Figure 2 illustrates experimental results.

From Figure 2, the pulse waveform is marginally improved for termination resistance greater than the characteristic impedance, but it becomes more unterminated-like when a terminating resistance less than the characteristic impedance is used.

Table 1 summarizes the effects of terminating resistance on transition times and propagation delays. The propagation delay of the line, 1.8 ns , has been subtracted from the experimentally-measured propagation delay in the data in Table 1. The propagation delay was measured as illustrated in Figure 3.


FIGURE 2. SENSITIVITY OF PULSE TO TERMINATING RESISTANCE


FIGURE 3. MEASUREMENTS

TABLE 2. SUMMARY OF TRANSITION TIMES AND PROPAGATION DELAYS

| R <br> $(\Omega)$ | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\mathbf{p h i}}$ |
| 0 | 4.0 | 2.6 | 3.1 | 5.0 |
| 30 | 4.6 | 3.6 | 3.8 | 6.0 |
| $80\left(=\mathrm{Z}_{\mathrm{O}}\right)$ | 5.4 | 5.8 | 4.8 | 8.0 |
| 130 | 8.4 | 7.4 | 5.6 | 10.6 |

Transition times are measured in the conventions 10\%/90\% and $90 \% / 10 \%$, and, similarly, propagation delay is measured between the $50 \%$ points of the waveforms.
Termination with a resistor equal to the characteristic impedance of the line adds 1.7 ns to 3.0 ns to the propagation delays and increases the transition times. From the perspective of the emissions problems discussed in Section 9.0, an increase in transition times is good. However, increased propagation delays may be undesirable from a functional standpoint. With $A C / A C T$, some termination resistance must be used to prevent ringing which could exceed the noise immunity limits.

## Shunt Termination with a Single

## Receiver

AC shunt termination is a means of approximating a resistive termination without incurring the power dissipation of resistive termination. In laptop computers, power drain is a battery life issue. In computers and other powerlinepowered digital equipment, power drain causes heat dissipation and implies a diminution in reliability. CMOS, in spite of its speed, consumes relatively little power while operating and near zero power while in standby (or high-Z) states. Therefore, in a total power "budget", it is important to consider the power dissipation of termination resistors.

Figure 4 illustrates the effects of AC shunt termination for two different values of capacitors.

In designing an $A C$ shunt termination, the value of the resistor is equal to the characteristic impedance of the line: $R_{T}=Z_{O}$. To allow for complete charging and discharging of the terminating capacitor $\left(C_{1}\right)$ during one-half the clock period: $\mathrm{C}_{1}<1 / 6 \mathrm{Z}_{\mathrm{O}} \mathrm{f}$. Then the power dissipated in $R_{T}$ is $V_{C C}{ }^{2} f_{C} C_{1}$ (see Table 7). For the present case of $\mathrm{f}_{\mathrm{C}}=12 \mathrm{MHz}$, and $\mathrm{Z}_{\mathrm{O}}=80 \Omega, \mathrm{C}_{1}<1 / 6 \mathrm{Z}_{\mathrm{O}} \mathrm{f} \mathrm{C}=$ 174 pF . At the extreme, where $\mathrm{C}_{1} \rightarrow \infty$, the power dissipation approaches that of a resistive terminator: $\mathrm{V}_{\mathrm{CC}}{ }^{2} / 2 \mathrm{Z}_{\mathrm{O}}$ for a $50 \%$ duty cycle clock.
For the case $\mathrm{C}_{1}=56 \mathrm{pF}$, the power dissipation in the terminating resistor is relatively small: 16.8 mW . For the case $\mathrm{C}_{1}=560 \mathrm{pF}$, the power dissipation approaches that of a resistive terminator: 156 mW (the power dissipation in the driver is approximately 30 mW ). However, the waveform with $\mathrm{C}_{1}=560 \mathrm{pF}$ is somewhat better than that with $\mathrm{C}_{1}=56 \mathrm{pF}$. In shunt termination, one is always trading power dissipation in the terminating resistor for pulse fidelity.

Table 3 summarizes propagation and transition times for $A C$ shunt termination.
table 3. PROPAGATION AND TRANSITION TIMES

| TERMINATION | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\mathbf{p h i}}$ |
|  | 4.0 | 2.6 | 3.1 | 5.0 |
| $80 \Omega / 56 \mathrm{pF}$ | 5.0 | 4.2 | 4.6 | 7.2 |
| $80 \Omega / 560 \mathrm{pF}$ | 5.8 | 4.6 | 4.2 | 7.0 |

AC shunt termination at the sending end (only) was not tried. However, in the context of distributed loads with both ends of the bus AC shunt terminated, the driving-end termination did not improve the waveform.

Ch. $1=2.000$ volts/div
Ch. 2 - 2.000 volts/div

Timebase - $10.0 \mathrm{~ns} / \mathrm{div}$


Since computer bus lines may be in the active high state for relatively long periods of time, the DC blocking capacitor, $\mathrm{C}_{1}$ (56pF and 560 pF in Figure 4), can be of considerable benefit when driving CMOS logic. However, when driving bipolar logic, the current required by the inputs of driven gates can total much more than that required by a terminating resistor without a DC blocking capacitor. Then, AC termination offers insignificant advantages over conventional resistive termination.

## Terminations Applicable to Distributed Loads

## Description of Board with Simulated Load

The circuit shown in Figure 5 is the simulated load used along the bus-like structure on the test board. It is patterned after the equivalent input curcuitry. The inductor was formed by a small loop of wire.


FIGURE 5. SIMULATED CMOS LOAD
The average value of the input capacitance of a CMOS gate is 7.5 pF . That value was not available, so 5 pF capacitors were used. The above load was distributed along one of the bus traces at points shown in Figure 6. The diodes are 1N914's, high-speed silicon types.


FIGURE 6. DISTRIBUTION OF SIMULATED LOADS ALONG bus trace.

The measurements and waveforms cited below were made at the gate four inches from the driver and at the gate at the end of the line. The points designated by arrows in the figure are referred to as the "intermediate gate" and "end gate" in the measurements to follow. In all cases, the waveform at the end gate was the worst case with respect to ringing.

When a load is distributed along a trace, the characteristic impedance of that trace is modified in accordance with [2, p. 148]
$Z_{O}=Z_{\infty} /[1+$ distributed load capacitance on line/ capacitance of line] ${ }^{1 / 2}$
$Z_{\infty}=$ Characteristic impedance of line without distributed loading.

In the case of the test board, the capacitance along the unloaded line of $0.72 \mathrm{pF} / \mathrm{in}$. $\times 12 \mathrm{in} .=8.6 \mathrm{pF}$, and the distributed load, including that at the last gate, was ( $4 \times 5 \mathrm{pF}$ ) $+7.5 \mathrm{pF}=27.5 \mathrm{pF}$. Then, $\mathrm{Z}_{\mathrm{O}}=80 /[1+27.5 \mathrm{pF} / 8.6 \mathrm{pF}]^{1 / 2} \approx$ $40 \Omega$.

## Series Termination

Figure 7 illustrates waveforms along the line for unterminated lines, with and without distributed loading, and for the series-terminated line with $R_{T}=Z_{O}$. It is clear from a comparison of the top two oscillograms that the presence of distributed loading-even without terminationtends to smooth the waveforms. At least in part, this is probably due to the diodes in the simulated loads, which are also present in CMOS input gates.

Distributed loading increases line propagation delays by the same factor by which the characteristic impedance is decreased, which is a factor of approximately two in the present case. Propagation delay measurements were taken as indicated in Figure 2, with $2 \times 1.8=3.6 n s$ subtracted from the measured propagation delays to provide the "distributed load" propagation times in Tables 4 and 5.

The problem with using series termination with distributed loading is that the waveform along the line will tend to become a three-level waveform [2, p. 53]. This tendency is clear in the third oscillogram from the top in Figure 7. Thus, in Table 5 the transition times at the intermediate point on the line are greater than those at the end of the line given in Table 4. If the bus was longer, the "kink" at a line voltage of 2.5 volts would be more noticeable. However, in the present case, transition times are great enough to smooth the otherwise sharp three-level waveform. In some applications, an increase in transition times may be acceptable, and the extra component in the form of the capacitor necessary for AC shunt termination-which does not "three-level" the waveform along the bus-is not necessary. AC shunt termination is discussed in the next section.


FIGURE 7. WAVEFORMS FOR DISTRIBUTED LOADING

TABLE 4. TRANSITION AND PROPAGATION TIMES-END GATE

| R <br> R <br> $(\Omega)$ | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\text {phi }}$ |
| O(No Dist. <br> load) | 4.0 | 2.6 | 3.1 | 5.0 |
| 0 (Dist. <br> load only) | 4.4 | 3.6 | 4.4 | 6.4 |
| $40\left(=\mathrm{ZO}_{\mathrm{O}}\right)+$ <br> Dist. load | 4.8 | 5.2 | 5.2 | 7.8 |

TABLE 5. TRANSITION TIMES-INTERMEDIATE GATE

| RT <br> $(\Omega)$ | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\text {phi }}$ |
|  | 6.6 | 5.6 | Not measured |  |
|  | 8.0 | 7.8 | Not measured |  |

## AC Shunt Termination

This termination technique was previously explored in the context of a single load. For the case of loads distributed along a single line, the advantage of shunt termination is that the tendency toward a three-level waveform with series termination is absent. Figure 8 illustrates the waveforms obtained with AC shunt termination. As previously discussed, the corrected (for distributed loading) value of the characteristic impedance is $40 \Omega$.
The discussion of trading off waveform integrity for power dissipation also applies here. The power consumed by
the terminating resistor when $\mathrm{C}=560 \mathrm{pF}$ is substantially greater than when $\mathrm{C}=56 \mathrm{pF}$.
Table 6 summarizes propagation and transition time data. As in the preceding section, gate propagation delay $=$ measured delay -3.6 ns .

TABLE 6. SUMMARY OF TRANSITION TIMES AND PROPAGATION DELAYS

| $\begin{aligned} & R_{T} \\ & (\Omega) \end{aligned}$ | TRANSISTION TIMES (ns) |  | PROPAGATION DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $T_{R}$ | $\mathrm{T}_{F}$ | TPLH | TPHL |
| $40 \Omega / 56 \mathrm{pF}$ |  |  |  |  |
| End Gate | 6.0 | 6.0 | 3.3 | 4.4 |
| Int Gate | 9.0 | 8.3 | Not measured |  |
| 40ת/560pF |  |  |  |  |
| End Gate | 8.0 | 8.3 | 3.7 | 8.0 |
| Int Gate | 8.8 | 9.0 | Not measured |  |

As is evident from a comparison of Tables 5 and 6, shunt termination with a small capacitor ( 56 pF ) does not extract as much propagation delay "penalty" as does series termination-nor does a 56pF shunt termination cause a tendency toward a three-level waveform on the bus. With a 560 pF capacitor, the waveform is better in the sense that there is less ringing, but, as indicated earlier, the power dissipation of the terminating resistor is substantially increased.

From a comparison of Figures 7 and 8, series termination appears to suppress ringing better than shunt terminationat least that shunt termination where, in order to reduce power consumed by termination resistors, the value of the capacitor is relatively small. Also, the increased transition times associated with series termination are very desirable from the standpoint of minimizing both ringing and ground bounce.

## Termination Techniques

Table 7 illustrates termination techniques which can be used at the receiving end of a trace; $C_{l}$ is the input capacitance of the driven semiconductor. The first three techniques require that the characteristic impedance of the trace structure be well-defined and constant along the trace run, which is complicated when a trace is to be run on both interior and exterior layers of a PCB.
Diode termination allows uncontrolled impedance-such as that obtained on a two-sided board where the trace-toground trace spacing is variable-but requires more expensive components than other techniques. In effect, CMOS input circuitry is a mixture of the series and diode termination techniques shown in Table 7.
In Table 7, the Termination Dissipation has been computed by assuming a (worst-case) $0 \Omega$ source resistance. The power dissipation expressions apply to use of the terminating networks at either end of the line. For example, the expression given for the dissipation of a series termination applies whether the termination is used on the sending (proper) end of the line or the receiving (improper) end of the line.

Series termination has been analyzed in some detail. For use at either the receiving or sending end, maximum clock frequency is determined by assuming that, after a high-tolow transition, the input capacitor, $\mathrm{C}_{\text {l }}$, must discharge to a voltage below 5\% of VCC before the next clock low-to-high transition. This requires that three $Z_{O} C_{l}$ time constants occur during one-half of the clock period, which leads to the clock-frequency limitation shown for series termination in Table 7.

The relatively large power consumed in termination resistors can be a problem. AC shunt termination, as defined in Table 7 and used in Figures 4 and 8, provides a worthwhile low-power alternative, to be applied at the receiving end of a trace. In AC shunt termination, pulse fidelity is traded off for power dissipation: the larger the value of the DC blocking capacitor, C1, the better the pulse, but the higher the power consumption of the terminating resistor.

In the limit as the value of C 1 is made very large, the power dissipation of the terminating network approaches that of purely resistive termination. The improved pulse fidelity with larger values of $\mathrm{C}_{1}$ is apparent from Figure 8 . The maximum value of C 1 which still permits adequate charging/ discharging of the shunt termination network over one-half of the clock cycle is $\mathrm{C}_{1}<1 / 6 \mathrm{ff}_{\mathrm{C}} \mathrm{Z}_{\mathrm{O}}$; this inverse clock-frequency limitation is given in the "Max fC " column of Table 7. However, for $\mathrm{C} 1 \gg 1 / 6 \mathrm{f}_{\mathrm{C}} \mathrm{Z}_{\mathrm{O}}$, the network is slow enough that full charging never occurs, the network begins to approach a purely resistive shunt terminator, and clock frequencies are limited only by the driver.
AC shunt termination should be used whenever the DC drive capability of the driving device is approached via heavy TTL loading.

## Decoupling CMOS

Clock-related noise on the $V_{C C}$ bus can arise if too few decoupling capacitors are used [5, p.3.11-1]. It
is recommended that all board layouts allow for one decoupling capacitor per semiconductor package. Howev$e r$, it is sometimes possible to remove some of the decoupling capacitors after a working prototype is developed. This is best done experimentally while carefully monitoring emissions, particularly at frequencies less than 200 MHz . At those frequencies, cable radiation dominates radiated emissions spectra. Assuming good grounding, cable radiation is an accurate indicator of VCC bus contamination.

On large ( $>50$-pin) devices with more than one $V_{C C}$ pin, use one decoupling capacitor at each $V_{C C}$ pin. In these cases, then, more than one decoupling capacitor per semiconductor package is recommended.

## Choosing the Value of a Decoupling Capacitor

A simplified diagram of the equivalent circuit for the output of a Harris CMOS device is shown in Figure 10. When the circuit shown transitions from low to high, switch S1 connects to terminal A and current is drawn from the VCC bus to charge the capacitor. On a high to low transition, the switch connects to B ; current is sourced by the capacitor as it discharges into ground through S1. Note that the switch is, in the ideal case, a "break before make" circuit, so that no current is drawn from $A$ to $B$ as S1 changes state - a common source of current consumption in early CMOS logic.

Departures from ideality include the totem-pole effect: for time intervals which are smaller than the transition time, both the upper (PMOS) and lower (NMOS) transistors are partially "on". Then, during both the low-to-high and high-to-low transitions, there is a pulse of current drawn from the $V_{C C}$ bus. This is in addition to the current pulse required-and predicted by the model-for the charging of $\mathrm{C}_{\mathrm{S}}$ when making the low-to-high transition. Also, the internal gates-those which precede the output gate-require both totem-pole and charging currents (charging currents for internal gates are much smaller than that required for the output gate, as the source capacitance associated with those gates is on the order of tens of femptofarads [1 femptofarad $=10^{-15}$ farad]).

A decoupling capacitor is the $V_{C C}$ bus for the purpose of supplying current during transitions. The inductance of a $V_{C C}$ trace or plane precludes those sources from supplying all of the rapidly-changing current required during a transition. Between clock pulse transitions, a trace or plane supplies recharge current to decoupling capacitors. Recharging can take place over the much longer time of one-half of the clock period.

A value of $0.1 \mu \mathrm{~F}$ will adequately decouple all known AC/ACT glue logic and VLSI circuits (even heavily loaded/fanned out), but the use of that relatively large value should be resisted in order to maintain the highest possible self-resonant frequency of the decoupling capacitor. Use $0.001 \mu \mathrm{~F}$ and $0.01 \mu \mathrm{~F}$, not so much for reduced cost as for the purpose of increasing the self-resonant frequency of the decoupling capacitor.


FIGURE 8. WAVEFORMS FOR AC SHUNT TERMINATION
table 7. receiving end termination techniques

| TERMINATION | MAX fc | TERMINATION DISSIPATION | PULSE INTEGRITY | NOTES |
| :---: | :---: | :---: | :---: | :---: |
|  | $\frac{1}{\underset{\left(667 \mathrm{ZOC}_{1}\right.}{ }}$ | $\begin{aligned} & \text { Very Low: } \\ & p=V_{C C}{ }^{\mathrm{f}_{\mathrm{C}} \mathrm{C}_{1}} \\ & (3.8 \mathrm{~mW}) \end{aligned}$ | Improves with small $z_{0}, c_{1}$ | Transition times increased. <br> Want Low ZO |
|  | Driver-Limited | Very High: $\frac{\mathrm{V}_{\mathrm{CC}}}{2 \mathrm{Z}_{\mathrm{O}}}(250 \mathrm{~mW})$ | Good Reflected \% $=\frac{4.4 Z_{O} C_{1}}{r_{r}-4.4 Z_{O} C_{1}}$ | Drive current $=\frac{V_{C C}}{Z_{O}}=(100 \mathrm{~mA})$ |
| AC Shunt (Controlled $Z_{O}$ ) | $\frac{1}{\substack{6 Z_{O} C_{1} \\ \text { (33.3MHz, see text) }}}$ | Low to Moderate, increasing with $\mathrm{C}_{1}$ $\mathrm{P}=\mathrm{V}_{\mathrm{CC}}{ }^{2} \mathrm{ff}_{\mathrm{C}} \mathrm{C}_{1}$ <br> (75mW, about same as device) | Best with largest possible value of $C_{1}=1 / 6 Z_{O f}$ Intergrity improves with $\mathrm{C}_{1}$ | Must use low-ESL $\mathrm{C}_{1}$ with short leads <br> Want Low $\mathrm{Z}_{\mathrm{O}}$ |
| Diode (Uncontrolled ZO) | Driver-Limited | Low | Good with highspeed Schotky diodes or built-in protection diodes of some semiconductors | External diodes costly |

* Examples are for $Z_{O}=50, C_{1}=5 p F, V_{C C}=5, f C=30 \mathrm{MHz}$, Duty Cycle $=50 \%$


FIGURE 9. RESISTIVE TERMINATION IS USED IN MOST STANDARD BUSES


FIGURE 10. EQUIVALENT CIRCUIT FOR CMOS OUTPUT

## The Equivalent Series Inductance (ESL) of a Decoupling Capacitor

The equivalent series inductance (ESL) of a decoupling capacitor and the inductance of the leads/planes used to connect the decoupling capacitor to a semiconductor package should be as small as economics and manufacturing practicalities permit. This decreases both ringing and emissions. It is shown in [5, pp. 3.9-7 through 3.9-10] that maximum attenuation of noise on the power bus occurs at the self-resonant frequency of the decoupling capacitor. To have that attenuation occur at frequencies where ringing and emissions suppression is otherwise difficult (generally 35 MHz to 90 MHz ) using a capacitor value chosen according to the previous section requires ESL's less than 10 nH . Surface-mount ("chip") capacitors on a multilayer board with both $V_{C C}$ and ground planes are particularly desirable.
The ESL of a decoupling capacitor is at least as important as its capacitance. Above the self-resonant frequency of a decoupling capacitor which provides filtering; that inductance should be as small as manufacturing techniques and economy permit.

## Placement of Decoupling Capacitor on a Board

A decoupling capacitor should always be placed on that end of the semiconductor package which points toward the power entry point on a board. One of the purposes of decoupling is to minimize $V_{C C}$ noise at the power-entry point, and the filtration implied by a decoupling capacitor should be between the semiconductor package and the power entry point.

## Conclusions and Recommendations

## Use Multilayer Boards

The inductances associated with two-sided boards are often too large for successful application of high speed

CMOS circuits. Two-sided boards designed from an RF standpoint could be used, but the low component density associated with such boards is inconsistent with most contemporary system design requirements.

## The "Best"' Termination Technique: Series Resistor at

 Driving EndWhen loads do not require much DC current, as with CMOS inputs, the preferred termination technique for a single load and large class of multiple distributed loads is a terminating resistor at the driving end of the trace. The value of the terminating resistor, $\mathrm{R}_{\mathrm{T}}$, is ideally equal to the characteristic impedance of the driven trace, $Z_{0}$, as modified by any distributed loading. The correction for distributed loading is given in equation 1.

Reduction of the value of a series terminating resistor from $R_{T}=Z_{O}$ leads to decreased propagation and transition times. However, for even zero-length traces, reduction of $R_{T}$ eventually leads to ringing. Although the internal diodes in the input circuitry of Harris CMOS tend to limit ringing, noise immunity problems can still occur.

Increasing the value of the terminating resistor beyond $\mathrm{Z}_{\mathrm{O}}$ tends to further enhance the smoothness of the pulse but can lead to undesirable increases in propagation delays. The resulting increased transition times tend to suppress emissions.

For driving-end series termination with distributed loading on lines 12 inches long, transition times at intermediate loads are doubled relative to those at the end of the bus. Longer buses lead to even greater increases in transition times at intermediate bus points. Should this not be tolerable, the alternative AC shunt termination discussed below should be used.

## An Alternative Termination Technique

In the above case and/or when a resistively-terminated bus and/or heavy TTL loads are to be driven by CMOS gates, AC shunt termination should be considered as an alternative to putely resistive termination.

At least for the driven-end terminated case considered in this report, AC shunt termination does not appear quite as effictive as sending-end series termination in suppressing ringing.

When terminating high-speed traces, SIP resistors and capacitors should be avoided. The equivalent series inductance (ESL) is too large in many applications. Discrete SMD's are preferred to minimize ESL.

## Minimize Power Bus Ringing to Minimize Interference

To minimize ringing on the power bus, it is recommended that CMOS devices which handle high-frequency periodic signals be carefully decoupled from the power bus. Specific decoupling recommendations have been provided in this report.

## Bibliography

[1] R.K. Keenan, FCC Emissions and Power Bus Noise (Second Edition), Pinellas Park, Florida: TKC, February 1988.
[2] William R. Blood, Jr., MECL System Design Handbook (Fourth Edition, Rev. 1), Phoenix, Arizona: Motorola Inc., 1988.
[3] RCA/GE/Harris Semiconductor, GE Solid State Data Book (for) RCA Advanced CMOS Logic ICs, Somerville, N.J.: GE Corporation, 1987.
[4] J.D. Kraus, Electromagnetics (Third Edition), New York: McGraw Hill, 1984.
[5] R.K. Keenan, Decoupling and Layout of Digital Printed Circuits, Pinellas Park, Florida: TKC, 1987.
[6] R.K. Keenan, Digital Design for Interference Specifications, Pinellas Park, Florida: TKC, 1983.
[7] H.H. Skilling, Electrical Engineering Circuits, New York: Wiley, 1958.

# TEMPERATURE CONSIDERATIONS 

Author: Clay Olmstead

## Junction Temperature

The energy expended by an integrated circuit is dissipated as heat. In a CMOS system, current (and hence power) increase proportionally with switching frequency. With the advent of fast CMOS circuits, the attendant rise in temperature causes a variety of problems. In some cases, the current and/or temperature constraints placed on the device by its operating environment are the limiting factors on the clock rate. The increased die temperature due to the switching speed produces a number of secondary effects. The propagation delay time of a CMOS gate increases, causing a decline in the overall performance of the system. In addition, the effects of various failure mechanisms are accelerated (see Reliability Fundamentals). Depending on the failure mechanism, the lifetime of the product can be decreased by a factor of two for every $10^{\circ} \mathrm{C}$ rise in junction temperature.
The internal temperature of a semiconductor device is defined as junction temperature, $\mathrm{T}_{\mathrm{J}}$. Harris products are designed to operate with a 10 year lifetime under the stated operating conditions. For parts in ceramic packages, these include a maximum junction temperature of $175^{\circ} \mathrm{C}$. For plastic packages, the maximum $\mathrm{T}_{J}$ is $150^{\circ} \mathrm{C}$ - this is to maintain the integrity of the package, not the device inside. Note that the $175^{\circ} \mathrm{C}$ limit is set according to military standards; many users in specific industries set this limit higher or lower, depending on their individual requirements.

## Determination Of Junction Temperature

Once the designer has selected an IC and calculated the clock frequency that meets the needs of the application, the operating temperature of the die (junction temperature) must be calculated to determine whether it exceeds reliability guidelines. This involves the concept of thermal resistance: the temperature differential across a body that is dissipating a given amount of energy. There are two common sets of reference points for thermal resistance: $\theta_{\mathrm{JC}}$ is the temperature differential between the p-n junction of a semiconductor device and the outside surface of the package (case); $\theta_{\mathrm{JA}}$ is measured from the junction to ambient conditions. Other reference points for measuring thermal resistance are defined depending on specific requirements.
To calculate whether a device will exceed its maximum junction temperature, the first step is to multiply the clock rate by the frequency coefficient (given in mAMHz ) for that product. This is listed in the D.C. Electrical Specifications section of
the data sheet under $I_{\text {ccop }}$ The total package power dissipation is calculated by multiplying that current by the maximum $\mathrm{V}_{\mathrm{Cc}}$. If this figure is less than the Maximum Package Power Dissipation listed in the data sheet, then the operating conditions meet Harris specifications. In some applications, it is necessary to operate the part using a higher junction temperature (for applications that can absorb the penalty in expected lifetime) or lower temperature (for high reliability applications). Users with these requirements calculate their actual junction temperature using one of the following equations. Given the maximum ambient temperature, the proper equation is:
$T_{J}=\left(\theta_{J A} \times P\right)+T_{A}$

## Equation 1

Where:
$\mathrm{T}_{J}=$ Junction Temperature of the Part $\ln { }^{\circ} \mathrm{C}$
$\theta_{j A}=$ Thermal Resistance from Junction to Ambient In ${ }^{\circ} \mathrm{C} / \mathrm{W}$ $P=I_{C C O P} \times V_{C C}$
$\mathrm{T}_{\mathrm{A}}=$ Ambient Temperature
The junction temperature for a given case temperature is:
$T_{J}=\left(\theta_{j c} \times P\right)+T_{C} \quad$ Equation 2
Where:
$\mathrm{T}_{J}=$ Junction Temperature of the Part $\operatorname{In}{ }^{\circ} \mathrm{C}$
$\theta_{\mathrm{JC}}=$ Thermal Resistance from Junction to Case In ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$\mathrm{P}=\mathrm{I}_{\mathrm{CCOP}} \times \mathrm{V}_{\mathrm{CC}}$
$T_{C}=$ Case Temperature

## Reducing Junction Temperature

If, after going through the above equations, the junction temperature exceeds the allowable limit, there are several possible solutions. With some types of parts, such as digital filters, the user can repiace a single part running at a high data rate with multiple parts, each operating at a reduced clock rate. Using this method, the junction temperature of each IC is reduced but the throughput of the entire circuit is unaffected. In most cases, the optimum solution is to improve the heat flow out of the package by adding a heat sink and/or forcing airflow across the package. Moving air lowers the effective $\theta_{\mathrm{JA}}$ of the part as shown in Figure 1. The required value for the effective thermal resistance is calculated by solving equation 1 for $\theta_{\mathrm{JA}}$ :
$\theta_{J A}=\left(T_{J}-T_{A}\right) / P$
Equation 3
Once the necessary value for $\theta_{J A}$ is known, Figure 1 is used to locate the corresponding air flow for the package of
interest. Note that the improvement in thermal impedance is a function of the airflow measured in linear feet per minute (lfm), but fan manufacturers measure airflow in cubic feet per minute (cfm). Assuming 100\% efficiency, lim is converted to cfm by multiplying the required lifm by the cross sectional area of the path of moving air. In reality, obstructions in the airflow cause back pressure, which diminish the fan output to between $60 \%$ and $80 \%$ of its free air capacity; divide the lfm figure derived from Figure 1 by this compensation factor to obtain the required fan output.


FIGURE 1. TYPICAL RELATIONSHIP BETWEEN $\theta_{\text {JA }}$ AND AIR FLOW FOR VARIOUS PACKAGES
Another viable solution is to use a heat sink, either by itself (natural convection) or with moving air (forced convection). There is a wide range of heat sinks available for virtually any package type. Note, however, that a heat sink is much more effective when used in combination with a ceramic package. This is due to the greater thermal efficiency of the ceramic material: most of the flow of thermal energy is from the die directly into the package, where the entire surface of the part acts as a radiating surface to let the heat escape. Some energy flows from the die through the bond wires and pins and out through the copper traces in the board, but this effect is negligible due to the fact that the bond wires are only 1 mil in diameter and thus their thermal impedance is relatively high. In a plastic package, the main path for the heat flow is from the die through the paddle and the plastic molding compound and on to the outside world. Since plastic is a relatively poor thermal conductor, other paths, such as the bond wires, take on a greater proportion of the total heat transfer so that their contribution is no longer negligible. For this reason, a heat sink mounted to a plastic package dissipates less heat than Equation 2 would indicate. Harris recommends the use of a ceramic package for operating conditions that require a heat sink.

Addition of a heat sink puts two additional elements in path of thermal transfer: the heat sink and the thermal joint compound that attaches it to the package. The total value for $\theta_{J A}$ is divided into its component parts: the thermal resistance from the junction to the surface of the package, from the package to the heat sink, and from the heat sink to ambient:
$\theta_{\mathrm{JA}}=\theta_{\mathrm{JC}}+\theta_{\mathrm{CS}}+\theta_{\mathrm{SA}}$
Equation 4
Where CS is the thermal resistance from the IC package to the heat sink, which is controlled by the mounting technique and thermal joint compound used. $\theta$ SA is the thermal resistance from the heat sink to ambient.

Under natural convection, heat sink dissipation is a function of the power dissipation of the chip. The heat sink manufac-
turer's catalog will specify the performance for their products using a chart similar to that shown in Figure 2. Starting with the power dissipated by the device on the $x$ axis, find the corresponding temperature rise of the package on the $y$ axis. Add this value to the ambient temperature, $T_{A}$, to find the elevated case temperature. Use Equation 2 to find the new junction temperature.
If a fan is to be used, then the following procedure is recommended. Use Equation 3 to calculate the required total thermal resistance. Solving Equation 4 for $\theta_{S A}$, calculate the maximum thermal resistance allowable for the heat sink. The literature from the maker of the heat sink will have a chart similar to Figure 3; find $\theta_{S A}$ on the right axis and find the air flow that corresponds to that value on the top axis. (The placement of the axes is to allow Figures 2 and 3 to be combined into one graph.) Convert lfm to cfm and divide that value by the compensation factor for back pressure mentioned above; use that figure to select a fan.


FIGURE 2. PACKAGE TEMPERATURE INCREASE AS A FUNCtion of power for a typical heat sink UNDER NATURAL CONVECTION


FIGURE 3. THERMAL RESISTANCE VERSUS AIR VELOCITY FOR TYPICAL HEAT SINK UNDER FORCED CONVECTION

## For Further Reading

The discussion above outlines the overall method for calculating the thermal parameters of a circuit. the interested reader may refer to the following references for further information.

MIL STD 883 Method 1012.1; JEDEC ENG. Bulletin No. 20, January 1975; 1992 Semi Std. Vol. 4, Methods G30-86, G32-86, G42-88, G43-87

## COMMON ABUSES OF THE HSP43220

1. Loads too many coefficients. Only "half" the coefficients (including center tap) are needed. Loading more or less coefficients will cause incorrect operation.
2. Improper reset of part. Both clocks must be active during reset. Both start pins high during reset and remain high until programming complete.
3. Starting part too soon. Under software control, the start pins may float momentarily before programming is complete. Once started, any writes of coefficients are ignored.
4. In DECIMATE, customer tries to bypass the HDF by setting Hdec $=1$ and Stages $=1$. The correct settings are HDec $=1$ and Stages $=0$.
5. Customer is violating the CK_IN duty cycle requirements when HDF is bypassed. See A.C. Specifications in data sheet.
6. Customer confuses even/odd symmetry bit with even/odd length filters.
7. Customer tries to run HDF bypassed with CK_IN = FIR_CK.
8. Customer thinks that taking the start pin inactive will stop the part. Only reset can stop the HDF section once it has been started.
9. Has intermittent or poor results from cheap socket or poor part insertion.
10. General - input rise/fall time to slow (>10ns), input setup/ hold violations, noise.
11. System board problems are causing incorrect acquisition of outputs from DDF. i.e. in a multiplexed bus structure there is bus contention.
12. Customer does not realize data is held at outputs until next DATA_RDY.
13. Customer does not relax passband attenuation as much as possibie and valuable taps are wasted.

## Debug Ideas

1. Bypass the FIR or HDF sections individually or together. If the clocks are tied together the HDF section can be pseudo bypassed by setting HDRATE as usual but set GROWTH $=50$ and STAGES $=0$. The HDF will output every Nth input sample. This will verify correct wiring of the DATA_IN bus and some of the C_BUS bits.
2. Read out coefficients as per memo.
3. Try writing F_DIS $=0$ then F_DIS $=1$ before loading coefficients. If this helps then poor reset procedure or floating start pins are likely.
4. Input a DC value, it should pass through a low pass filter.
5. Are DATA_RDY's at correct frequency? (CK_IN/( $\left.\mathrm{H}_{\text {dec }}+\mathrm{F}_{\text {dec }}\right)$.


No. TB311 January 1994

## Harris Digital Signal Processing

## HSP43220 - DESIGN OF FILTERS WITH OUTPUT RATES <2(Passband + Transition)

One of the design rule checks in DECl•MATE is that the output rate must be greater than 2 times the sum of passband + transition band. For the informed user, violation of this rule is a valid design choice. Suppression of this rule check in DECloMATE is not possible, but design of such a filter using DECl•MATE is possible.

The general solution is to use DECl•MATE to design a filter with an output rate that is twice the desired rate, or a integer multiple of the desired rate that is $\mathbf{> 2}$ (pass + trans). Outside of the Design Module the FIR decimation rate is increase by the factor needed to achieve the desired output rate. The new filter response is obtained graphically.

Consider a filter with a passband of 70 KHz and a transition band of 60 KHz . The desired output rate is 200 KHz . DECl-MATE requires an output rate of $>260 \mathrm{KHz}$, an output rate of 400 KHz is chosen (see Figure 1 below and FILTER 1 page 2).

By increasing the FIR decimation by a factor of 2 the folding point ( $F_{\mathcal{S}} / 2$ ) is moved and the desired output rate is obtained. The filter response can be generated graphically. The aliasing component is represented by the dotted line (see Figure 2 below).


FIGURE

Notice in FILTER 1 the stopband attenuation was limited to 40dB (FIR_CK=CK_IN). Because the FIR decimation was increased from 5 to 10, there are more taps available with FIR_CK=20MHz. Using equation 2.0 from the 43220 data sheet, we see how many taps are available.

$$
\text { \#Taps }=\left(\frac{2 \times 20(10) 10}{20}-10-4\right)=172
$$

We can therefore use FILTER 2 which uses 151 taps and has 96 dB stopband. The part will of course be programmed for FIR decimation rate of 10 and an FIR_CK of 20 MHz is used.

To correctly simulate or generate PROM files for the "new filter" the *.DAR file must be edited. The corrected value for FDRATE on line 1 column 4 is entered. The correct output rate and FIR_CK rate are entered on the next to the last and the last line of the *.DAR file.

The above procedure works for standard or Precomp FIR. Remember the maximum FIR decimation rate is 16.


FIGURE 2


FIGURE 3. FILTER DESIGN USING STANDARD TECHNIQUE.



FIGURE 4. FILTER DESIGN DISREGARDING FIR CLOCK (MIN).

# HSP43220 DECl•MATE DESIGN RULE CHECKS 

In order to maximize effectiveness of DECI•MATE software there are two design rule checks that need some in depth discussion. Once these crosschecks are understood the usefulness of DECI•MATE and the DDF will improve because filters that were previously thought unrealizable are in fact achievable. Consider the following normalized HDF response (to first null).

In Figure 1 the dotted line represents aliasing. The point defined by stopband attenuation ( 50 dB ) and the sum of the passband and transitionband frequencies, must not cross the dotted line. Sometimes in MANUAL design mode you will come upon a filter in which you can vary either the transitionband or passband frequencies or attenuation by just a few Hz or a few dB , and find the filter jumps from unrealizable due to many taps to a viable filter that only needs a few taps. This may be due to crossing the aliasing curve. This in effect, renders the HDF ineffective and DECloMATE is trying to accomplish everything in the FIR. You may also get the error message "HDF unrealizable".


Violation of the second rule exhibits similar symptoms.
Figure 2 illustrates the design rule check that the HDF rolloff should not violate the passband attenuation spec. This condition can occur in a variety of ways, if the passband is a
large percentage of the output rate, if the passband attenuation is very small, if most of the decimation is being done in the HDF (which brings the first null of the HDF response in close to the passband region). The number of stages in the HDF also determines the rolloff of the HDF response. This design rule check is done with no knowledge of the type of FIR being used, STANDARD, IMPORTED, or PRECOMP. Therefore switching to a PRECOMP, or IMPORTED FIR will not alleviate a violation of this rule. The PRECOMP FIR can in fact reduce the HDF rolloff effect when the rolloff is within the limits stated above.


FIGURE 2.

It is important the user understand which rule is being violated because the first one is hard and fast, must not be violated. The second is correctable with additional work (manual design of FIR on other software). It is of course possible that both rules are being broken. There are two simple tests that can be done to identify what the problem is. If the difficulty is with HDF rolloff in the passband (rule 2), then relaxing the passband attenuation will allow the software to generate a filter.

If the problem is intrusion of stopband attenuation past the dotted line (rule 1), then changing the passband attenuation will not solve anything. Try reducing the stopband attenuation, a little, then a lot, if this results in a filter design then the problem is rule 1.

## Solutions

If $\mathrm{DECl} \cdot \mathrm{MATE}$ was in design mode MANUAL when the problem occurred then the user can adjust the design parameters (input rate, output rate, passband, transition band, passband attenuation, stopband), or the HDF filter parameters to achieve a filter. For problems with rule 1 try any of the following: higher input rate, narrower passband, less stop-
band attenuation, less HDF decimation, more HDF stages. For problems with rule 2 try any of the following: higher input rate, higher output rate, narrower passband, looser passband attenuation, less HDF decimation, fewer HDF stages.

In general, if DECl•MATE was in design mode AUTO when the problem occurred, then going to manual design mode and playing with HDF stages, or HDF decimation will not produce any better results (with the one exception noted below as "Special Case"). The user then must decide if the system can tolerate the relaxed design parameters (input rate, output rate, passband, transition band, passband attenuation, stopband attenuation) needed to achieve a realizable filter. If not, the user will need to perform a manual design of the HDF and FIR filter parameters.

## Special Case

For those users who have the option of low system decimation rates there are some alternatives. For those with system decimation rates of less than 10, trying varying combinations of HDF decimation and HDF stages may prove worth while. Also, for those that can have system decimation of 16 or less, bypassing the HDF (setting HDF decimation to 1 and HDF stages to 0 ) and using only the FIR may be beneficial.


## NOTES ON USING THE HSP43220

## Operation And Programming

Typical operation of the part using DECI•MATE software is as follows. RESET\# is held low long enough to satisfy the specification of 4 clocks for the slowest clock. Coming out of reset both start inputs must be high. After waiting the specified reset recovery time the registers are then loaded. H_Register1: H_DRATE register will accept values from 0 to 1023. H_BYP is set as desired. F_CLA is typically set to a zero, F_DIS is set to a zero. H_Register2: H_STAGES is set as desired, a six or seven may be entered and will be interpreted as a five. H_GROWTH is entered as specified in the data sheet or DECl•MATE with acceptable values from 0 to 63, with values above 50, the most significant bits of the input data will be dropped. F_Register: F_TAPS will accept values from 2 to 511 . DECI•MATE always generates odd tap filters, therefore the value N to be entered will typically be even. F_DRATE, enter value between 0 and 15 as desired. F_ESYM, as with most filter design software, DECI॰MATE always generates even symmetric filters, enter a one. F_BYP, enter as desired. F_OAD, typically set to a zero, used only for non-symmetric filters and for verifying filter coefficients. FC_Register, for a the value $N$ loaded in the F_TAPS register there will be (N/2)+1 coefficients to be entered for odd length filters and N/2 coefficients for even length filters. It takes two writes to load each coefficient. Internally the number of coefficients loaded is recorded and used to determine the length of the filter, NOT F_TAPS. F_TAPS is used to offset a read pointer in the data RAM and to determine if an odd or even number of taps is being done to properly handle the center tap.
With programming of the HSP43220, the part must be started as described in the data sheet. If STARTIN\# is used, it will be the third rising edge of CK_IN (from STARTIN\# active) that the DATA_IN pins will start accepting data. If ASTARTIN\# is used it will be the fifth rising edge of CK_IN.
If at any time RESET\# goes active, or glitches low, the above procedure must be repeated (except for reloading coefficients). Also see reprogramming.

## Implementing Non-symmetric Filters

The HSP43220 can implement up to a 256 tap non-symmetric filter. Correct programming procedures are as follows. By definition the number of coefficients loaded is equal to the
number of taps ( $N$ ). The F_TAPS is set equal to $2 \mathrm{~N}-1$, and F_OAD and F_SYM are set to a one. The remaining registers are loaded normally.

## Data_in Bus

In many cases the source of information to be fed into the DATA_IN pins will be less than 16 bits wide. The recommended configuration is to connect the input bus to the most significant bits of DATA_IN and to tie unused DATA_IN pins to GND. In some systems there will be available a 16 bit bus to connect to the DATA_IN pins but the full range of the bus is not being used. For example the upper 4 bits are always sign bits. This can be adjusted for in software by setting the growth for three more than normal. Even if the HDF is to be bypassed this can be accomplished by manually putting the HDF in bypass. This is done by setting H_STAGES and H_DRATE to 0 . For the case described above, H_GROWTH would be set to $50+3$, or 53 . This pushes the 3 extra sign bits off the top of the data shifter.

## Output Format

As stated on page 4-5 of the DECl•MATE manual, the FIR coefficients are computed using the Parks-McClellan (Remez) method and then scaled by the inverse of the HDF scale factor as well as an additional factor which accounts for the maximal ripple gain of the derived FIR. As a result, the output format is as follows. DATA_OUT bits $0-15$ are the most significant bits. If OUT_SELH is held high, then DATA_OUT bits 16-23 are simply sign extension, if held low they are the LSB extension, for a total of 24 bits of resolution. For those that wish more bits of resolution the sign extension bits can be used. This may be accomplished through the users own software or the coefficients from DECl-MATE may be scaled. This is accomplisted by determining the magnitude of the largest coefficient, and then multiplying all coefficients by the factor $0.999999 / \mathrm{mag}$. The coefficients must then be quantized to 20 bits. This results in the magnitude of the largest coefficient being about 0.999999 , the largest representable value. This procedure also allows the realization of filters of greater than 96 dB attenuation since it reduces quantization effects. The new position of the deci-
mal point in the output will be moved into the sign extension bits with its exact position being dependent on the coefficients.

## Bypass Modes Of The HDF And FIR

When the H_BYP bit is set, H_Register2 bits are affected as follows. H_GROWTH is set to 50, H_STAGES is set to zero. The clock divider is disabled so CK_DEC=CK_IN. The H_Register1 value H_DRATE is not altered by setting the H_BYP bit. H_Register2 must be reloaded after H_BYP has been returned to a zero.

With H_BYP set to a one, the feedback paths in the integrators and the holding registers in the comb are zeroed. The 16 bits of chip input data pass through the HDF section unaltered. As always, the first data sample out of the HDF (after reset/startup) is a zero due to resetting of the data paths. Because the FIR section has several operations to complete between rising edges of CK_DEC it is necessary for FIR_CK to be faster than CK_IN as described in the data sheet. The duty cycle of CK_IN must meet the conditions described Tech Brief TB312. DECIMATE can be used to determine the necessary frequency of FIR_CK or equation 1.0 in the data sheet can be solved for the case of HDF in bypass by setting $\mathrm{Hdec}=1$.

When the F_BYP bit is set the FIR filter is configured as a 3 tap, even symmetric filter, no decimation with one input to the pre-adder set to zero (same side as if F_OAD was set). The output of the coefficient ram is forced to 00004 H to aid in positioning the result in the accumulator. The output multiplexes are set by the F_BYP bit to output data from the bottom of the accumulator. For a 3 tap filter there are two multiply/accumulate (MAC) cycles. The data flow is as follows. A new piece of data becomes available at the HDF output as signaled by a rising edge of CK_DEC. The FIR is signaled and the data is written into the data ram. The first MAC cycle begins. From the data ram the new data and some old data are read. The new data is added to zero in the pre-adder, then multiplied by the coefficient, and then accumulated with a zero (because start of new FIR cycle). The second MAC cycle starts one FIR_CK cycle after the first. Two old pieces of data are read from ram. But two zeros are input to the pre-adder because of zeroing the other side of the pre-adder at the center of odd length tap filters. The resulting zero is multiplied by the coefficient and accumulated. The accumulator results are sent to the output pins along with a DATA_RDY.

## Reprogramming

After initial startup of the HSP43220 the FIR section can be reprogrammed using the F_DIS bit of H_Register1. When writing H _Register1 be sure to maintain the same values in bits $0-10, H_{2}$ DRATE and $H_{Z}$ BYP. When the F_DIS bit is written the FIR section will terminate a FIR cycle if one is in progress, no DATA_RDY is issued. The FIR section is disabled from performing multiply/accumulate cycles. The FIR_CK must continue to run. The HDF section continues to operate and its output continues to be written into the data ram. By letting the HDF section continue to run the synchro-
nous operation of multiple DDFs is maintained. By continuing to load the data ram a transient response is avoided when the FIR section is restarted. Writing the F_DIS bit also resets the coefficient ram address pointer to zero (to allow for reloading coefficients) and enables writing of the coefficient ram (writing is disabled when FIR section is enabled). Once the bit is set and at least two rising edges of FIR_CK have occurred, the user may then reconfigure the FIR section as desired. The FIR section can be re-enabled either by writing F_DIS to a zero or by generating a high to low transition on either of the start inputs, which automatically clears F_DIS.

For those users that wish to clear the HDF data paths before bringing in a new signal, or for those that wish to change HDF programming and have multiple DDFs running synchronously, activating the RESET\# input is recommended. Re-programming the DDF and restarting will be necessary. The coefficient ram is not corrupted by reset and will not need to be reloaded unless new coefficients are needed. It is also possible to reconfigure the HDF without losing synchronization between DDFs if CK_IN is stopped (high or low) during writing of the registers. For single chip applications or where synchronization is not a concern, the HDF registers can be written on the fly. This will result in a transient response and changing HDF registers at regular intervals in an attempt to achieve fractional decimation rates with the chip is not recommended.

## Internal Decimation

The total decimation in the DDF, also called the system decimation, is equal to the product of Hdec and Fdec. The output rate of the DDF will be equal to CK_IN divided by system decimation, regardless of FIR_CK speed. The time from the start of the DDF to the first DATA_RDY may not be the same as time between DATA_RDYs. To the user the FIR decimation appears at the FIR output. That means the output of the DDF is equivalent to using a standard FIR filter and only looking at every Nth output for FIR decimation of N .

In the HDF the counter used for decimation is initialized to Hdec. The first CK_DEC (internal to chip) will occur about Hdec CK_INs after the part is started. The FIR decimation counter is initialized to zero and the first CK_DEC will always cause an FIR cycle which generates a DATA_RDY about taps/2 FIR_CKs later. Thus the time delay from start of the DDF to the first DATA_RDY is about CK_IN period times Hdec plus FIR_CK period times taps/2.

## Transient Response

After reset, after changing the source of input data, or after re-programming the HDF, the output of the DDF will have a transient response until the data ram is sufficiently full of "valid" data. There is no transient response when only the FIR is reprogrammed using the FIR disable bit in the control register. It is impossible to predict exactly when the transient is complete as the answer depends on the FIR filter coefficients as well as new data values relative to old data values in both the FIR and HDF.

First the integrator stage(s) must be flushed of old data (except when reset is used). The number of stages and growth will influence this. But in general the flushing of the integrator stages is small compared to the remainder of the chip. For $N$ stages it will take $N$ CK_DEC cycles to flush all the holding registers in the comb. The number of taps determines how many locations of the data ram needs to be written with new data. The equation for the number of input samples needed to complete the transient response is:

$$
\text { number of input samples }=\mathrm{Hdec}(\text { taps }+\mathrm{N})
$$

The number of output samples that are part of the transient response is:

$$
\text { number of output samples }=\operatorname{taps} / F d e c+N / F d e c
$$

Because the center coefficients are usually much larger than outer coefficients the transient response is done before all the ram locations are filled. In some cases in half the time described above.

The simulator in DECI•MATE assumes all unwritten ram locations are zero and may not necessarily reflect the startup transient of the DDF. This can be overcome by making sure leading zeros are input ahead of the signal for both the simulator and the chip. For the case of the data input changing (one signal followed by another) the simulator will match the DDFs transient response. You cannot simulate reprogramming the DDF.

## Clock Inputs

The requirement that the two input clocks be synchronous is driven by the handshake circuitry between the HDF and FIR section. In this circuitry there is a flip/flop which has CK_DEC as the data input and FIR_CK as the clock input. Based on the theory that it is impossible to design a synchronizer that
is $100 \%$ immune to metastable conditions it was needed to specify the FIR_CK and CK_IN inputs as synchronous inputs. Metastable condition refers to when the flop output oscillates due to the data and clock changing simultaneously. For the user that finds it very inconvenient to use synchronous clocks, or for one that does not wish to use clocks that are integer multiples (which is by definition not synchronous), the use of a local synchronizer can be of benefit. This option puts the risks and control of metastability at the board level under user control. One example of this might be a user that has designed the needed filter in DECl॰MATE and the required FIR_CK is 35 Mhz with a CK_IN rate of 5 Mhz . Through the use of equation 1.0 in the data sheet the minimum FIR_CK is 32 Mhz . The software chose 35Mhz because it is smallest integer multiple (30Mhz would have been to slow). Assume the fastest available speed grade of HSP43220 is 33Mhz. The user may then use a local synchronizer to make the filter realizable. The following is just one example of a local synchronizer that re-aligns the system clock edges to create a synchronous CK_IN.

The following restrictions are needed to insure maximum performance.

1. System clock must have high and low times greater than oscillator period.
2. Have to still meet DATA_IN setup and hold times at DDF pins. Use of $Q$ bar output makes this easier.
3. Realistically the maximum system clock rate is one sixth of oscillator.
Node A can still become metastable but it has one oscillator period to become stable. The user has access to node $A$ and can make his own evaluation as to if the circuit performance is acceptable. In general the higher the speed capabilities of the flip/flops used makes for faster resolution of the metastable condition if it should occur.

## HDF BYPASS IN THE HSP43220

When HDF bypass is selected special timing restrictions exist for signal CK_IN.

When no decimation is selected for the HDF section either by setting the H_BYP bit to 1 or by setting H_DRATE $=0$, the timing requirements for CK_IN require special consideration. The FIR section of the chip is signaled that there is new data from the HDF when a transition is detected on the signal CK_DEC (see Figure 1). Failure to meet the timing requirements on CK_IN when $H_{d}=1$ results in no or erratic DATA_RDY pulses being issued.


FIGURE 1. CK_DEC GENERATION AND DETECTION
When $H_{d}>1$, the internal divider sets the high or low time of CK_DEC equal to the period of CK_IN, guaranteeing that CK_DEC will be detected by FIR_CK (Figure 2). When $\mathrm{H}_{\mathrm{d}}=$ 1, the duty cycle of CK_DEC is the same as CK_IN as shown in Figure 3.


FIGURE 2. CIRCUIT TIMING WHEN $H_{D}=2$


By definition of valid part operation, any time $H_{d}=1$ the FIR_CK will be at least 2 times the frequency of CK_IN.

In the example shown in Figure 3, the state of CK_DEC is always a zero when sampled by the rising edge of FIR_CK. To insure that signal CK_DEC is sampled in both its high and low state by the flipflop requires careful control of CK_IN. The most obvious solution is for the high or low time of CK_IN to be a minimum of one period of FIR_CK. This guarantees sampling both a 1 and a 0 no matter what the phase relation of FIR_CK and CK_IN is.

There is a specified range of allowed phase offset between FIR_CK and CK_IN as given in the AC specifications by spec TSK. Using this spec with 2ns of margin yields the following minimum CK_IN high or low time with setup and hold as specified.


FIGURE 4.

For a 25 Mhz part the minimum high or low time requirement for CK_IN is 19ns (when $H_{d}=1$ ) given the above timing (independent of clock frequencies).
For the typical user, guaranteeing the CK_IN high and low times greater than or equal to the period of FIR_CK will be the most desirable solution in terms of hardware. For the user with additional system constraints, such as those that vary the frequency of CK_IN but hold a high or low time constant, the above timing yields the most flexible solution.

## READING OUT FIR COEFFICIENTS FROM THE HSP43220

There are two methods of reading out the FIR coefficients. With method 1, a single coefficient is output with every DATA_RDY. With method 2, a coefficient is output every rising edge of FIR_CK.

## Method 1

The premise is to configure the 43220 to look like a FIR filter, input an impulse, and observe the coefficients at the output.
First, the FIR section of the chip is programmed for no decimation ( $F_{d e c}=1$ ). This may require changing H_DRATE from the original setup (see BYPASSING THE HDF). The F_REG is written for the original value of $F_{-}$TAPS, $F \_B Y P=0$, F_OAD $=0, F_{-} E S Y M=1, F \_D R A T E=0$, and $F \_C L A=0$ (H_REG1). The FC_REG is loaded normally. The FIR data ram must be sufficiently filled with zeros before the impulse. The minimum number of zeros to clock into the 43220 is Hdec*taps. The pin OUTSELH should be set to a zero. An impulse, value 0800 H , is input and the coefficients will be output in the order, outer coeff through center coeff and back to outer coeff. The 20 bit coefficients are output on the 24 DATA_OUT pins with the format shown below.

## Method 2

This method allows for reading out the FIR coefficients in less time than method 1 but requires the system to have the ability to capture the value on the DATA_OUT pins every FIR_CK. DATA_RDY has no meaning in this mode. The HDF section must be configured as described in the BYPASSING THE HDF portion of this memo. For an NTAP filter, the value for F_TAPS is either NTAPS or NTAPS-1, which ever is odd. For example, for either a 67 or 68 tap filter, F_TAPS $=67$. Set other FIR parameters as follows: $F_{-} B Y P=0, F \_O A D=1$, F_ESYM $=1$, F_DRATE $=0$, and F_CLA $=1$

Instead of an impulse, the DATA_IN pins are held at the value 0800 H . After (taps/2)(Hdec+10) CK_IN cycles, all the coefficients will be output on consecutive FiR_CKs in the order in which they were written.

## Bypassing The HDF

Use the following equation to determine the $H_{d e c}$ required with $F_{d e c}=1$ (if $F_{d e c}$ was equal to 1 in the original filter then the correct $\mathrm{H}_{\text {dec }}$ is already known).

$$
H_{D E C}=\frac{C K \_I N[(\operatorname{taps} / 2)+5]}{\text { FIR_CK }}
$$

Round the resultant value for $H_{d e c}$ up to the next integer value.
For $H_{d e c}=1$, set $H_{1} B Y P=1$, in this case an impulse is defined as the DATA_IN pins having the value 0800H for one rising edge of CK_IN.
For $H_{\text {dec }}=N, N>1$, set $H B Y P=0, H_{-}$DRATE $=N-1$, H_GROWTH $=50, H_{3}$ STAGES $=0$. In this case an impulse is defined as the DATA_IN pins having the value 0800 H for N rising edges of CK_IN (see Figure 1).


FIGURE 1

## OUTPUT FORMAT

DATA_OUT


SE-SIGN EXTENSION


# QUADRATURE DOWN CONVERSION WITH THE HSP45116, HSP43168 AND HSP43220 


#### Abstract

The Harris HSP45116 Numerically Controlled Oscillator/ Modulator (NCOM) can be combined with a low pass filter to perform down conversion on a digital signal. The NCOM rotates the spectrum of a real or complex signal and outputs a complex data stream. The signal of interest is now at base band, so that the output can be low pass filtered to eliminate unwanted signals (Figure 1).




FIGURE 1. DOWN CONVERSION SPECTRAL PLOTS

If the spectrum of the signal of interest is sufficiently narrow, the output sample rate of the filter can be reduced to ease the throughput requirements of the downstream processing. Reducing the sample rate of a signal is commonly known as decimation. The input sample rate divided by the output sample rate is known as the decimation factor, or simply decimation. Note that decimation by one is equivalent to no decimation, and decimation by less than one is undefined. For the purposes of this discussion, base band signals will be divided into two categories: wide band signals, where the decimation factor is 16 or less, and narrow band signals, where the decimation is greater than 16.

## Narrow Band Down Conversion

For narrow band output signals, Harris has a three chip set with a filter that is capable of decimation by up to 16,384 . Figure 2 shows how the NCOM and HSP43220 Decimating Digital Filter (DDF) are connected to perform down conver-
sion and real to quadrature conversion of an input signal. This is a generalized block diagram which can be used as the basis for a specific design.

Several assumptions were made in defining this block diagram. Among these assumptions are:

- Input and output data are sixteen bits. Users requiring less than that should keep bit 15 as the most significant bit, grounding the unused bits on the input of the NCOM. In all cases, bits 0 through 15 on the output of the NCOM should be connected to the sixteen input bits of the DDF. To select the output bits of the DDF, note that if the input is a cosine at frequency $A$ and the NCOM is tuned to frequency $B$ and the phase offset is 0 , then the real and imaginary outputs of the NCOM at sample n are:
- Real Output: $\cos (A n) \cos (B n)=[\cos (A n-B n)+\cos (A n+B n)]$
- Imaginary Output: $\cos (A n) \sin (B n)=[\sin (A n+B n)-\sin (A n-B n)]$
- Note that the factor of $1 / 2$ has been omitted. The output of the Complex Multiplier is shifted left by one bit internally. For this reason, both the real and imaginary outputs have the same magnitude as the input.
- The Phase Register is selected to control the phase of the NCOM (as opposed to MODO-1) and is initialized along with the center frequency. In this example, the LOAD\# signal is not exercised, so the initial phase of the NCOM is unknown.
- To shift the positive component of a real input signal to base band, the Center Frequency Register of the NCOM is set to a negative number.
- The Offset Frequency Register, Timer Accumulator and Complex Accumulator of the NCOM are not used.
- The filter clocks of the two DDFs are driven at a higher rate than the input data clocks. For many applications the FIR_CK, CK_IN and CLK signals can all be connected together. In this case the divide by N block is not needed.
- The DDFs are reset and started asynchronousiy with a pulse generator that receives asynchronous commands from an outside source and drives the two DDFs simultaneously. The DDF receiving the asynchronous start pulse performs the synchronization and starts the other part at the proper time.


FIGURE 2. BLOCK DIAGRAM FOR QUADRATURE DOWN CONVERSION WITH HSP45116 AND HSP43220.


FIGURE 3. BLOCK DIAGRAM FOR WIDE BAND QUADRATURE DOWN CONVERSION WITH HSP45116 AND HSP43168.


FIGURE 4. BLOCK DIAGRAM FOR WIDE BAND DOWN CONVERSION WITH HSP45116 AND HSP43168.

## Wide Band Down Conversion

Figures 3 and 4 show how the NCOM and HSP43168 Dual FIR Filter (Dual FIR) are connected to perform down conversion and real to quadrature conversion of an input signal. Because the Dual FIR can implement either one or two filters, two block diagrams are shown. Figure 3 shows the case where each 43168 is implementing a single filter. The maximum number of coefficients in this case is 16 times the decimation factor for each filter. Figure 4 shows the same configuration with the exception that the Dual FIR is now configured as two independent filters, each with a maximum length of 8 times the decimation factor.

These are generalized block diagrams which can be used as the basis for a specific design. Note that they do not represent detailed schematics with all gates represented. For instance, the control signals are driven with a single PAL22V10 operating as a self contained state machine; it reality, the 22V10 may not have enough gates to generate all the necessary output sequences; in that case, it would be necessary to have a counter generate the states and use the PAL to decode the counter output, generate the control signals to the 43168, and reset the counter when the sequence is completed.

The design parameters of these circuits are:

- Input data is 10 bits. Users requiring less than that should keep bit 15 as the most significant bit of the NCOM, grounding the unused bits on the input. In all cases, bits 6 through 15 on the output of the NCOM should be connected to the input bits of the Dual. To select the output bits of the Dual, note that if the input is a cosine at frequency $A$ and the NCOM is tuned to frequency B and the phase offset is 0 , then the real and imaginary outputs of the NCOM at sample $n$ are:
- Real Output: $\cos (A n) \cos (B n)=[\cos (A n-B n)+\cos (A n+B n)]$
- Imaginary Output: $\cos (A n) \sin (B n)=[\sin (A n+B n)-\sin (A n-B n)]$
- Note that the factor of $1 / 2$ has been omitted. The output of the Complex Multiplier is shifted left by one bit internally. For this reason, both the real and imaginary outputs have the same magnitude as the input.
- The Phase Register is selected to control the phase of the NCOM (as opposed to MODO-1) and is initialized along with the center frequency. In this example, the LOAD\# signal is not exercised, so the initial phase of the NCOM is unknown.
- To shift the positive component of a real input signal to base band, the Center Frequency Register of the NCOM is set to a negative number.
- The Offset Frequency Register, Timer Accumulator and Complex Accumulator of the NCOM are not used.
- The decimation rate in the Dual FIRs is greater than one. For no decimation, TXFR\# should be grounded. Note that the maximum number of coefficients in the 43168 is eight or sixteen times the decimation rate, depending on the mode (see above).


## Combined Narrow And Wide Band

In some applications, it is necessary to pass both wide and narrow band signals. In this case, both the HSP43220 and HSP43168 can be used in parallel, with the user selecting the output of either set of chips, depending on the characteristics of the signal of interest. Figure 5 shows this application, with most of the control signals eliminated for clarity. (These signals can be derived from the previous block diagrams.) In addition, note that the input data clock (CK_IN) and the FIR clock (FIR_CK) of the DDF have been connected together. This configuration is applicable when the input data rate is sufficiently high to allow the filter to operate at this rate also. If this is not the case, the divide by N circuit used in Figure 2 could be used, with the high speed clock driving the FIR_CK pins and the divided down clock used for all other clocks in the circuit.

## New Products

Now available from Harris are the HSP50016 Digital Down Converter, which is a single chip quadrature down converter and low pass filter (Figure 6). In addition, the HSP43216 Half Band Filter allows the user to double the input sample rate of the NCOM for real signals (Figure 7). Contact your local Harris sales office or representative for more details on these and other new products from Harris.


FIGURE 5. BLOCK DIAGRAM FOR QUADRATURE DOWN CONVERSION WITH HSP45116, HSP43220 AND HSP43168


FIGURE 6. BLOCK DIAGRAM OF HSP50016 DIGITAL DOWN CONVERTER


FIGURE 7. HALF BAND FILTER IN QUADRATURE DOWN CONVERSION

## Harris Semiconductor



No. TB316 January 1994

## PIPELINE DELAY THROUGH THE HSP45116

The following timing diagrams show the pipeline delays through the HSP45116 NCOM from the time that data is applied to the inputs until the outputs are affected by the


FIGURE 1. FREQUENCY TO OUTPUT DEL.AY


FIGURE 3. PHASE MODULATION TO OUTPUT DELAY
change. The delay is shown as a number of clock cycles, with no attempt made to accurately represent the setup and hold times or the clock to output delays.


FIGURE 2. PHASE TO OUTPUT DELAY


FIGURE 4. VECTOR INPUT TO OUTPUT DELAY


## READING THE PHASE ACCUMULATOR OF THE HSP45106

The block diagram shown below illustrates the method of reading the phase accumulator of the NCO16 from a microprocessor. The setup shown is very similar to that used when the part is used for generating a complex sinusoid, except that the internal SIN/COS lookup is bypassed by putting a logic 1 on the TEST pin. While the TEST pin is high, the phase accumulator continues to drive the inputs of the SIN/COS Generator while the most significant 28 bits of the phase accumulator are multiplexed out onto the output pins. Because of this, the part can be operated in two modes, one where the SIN/COS Generator is permanently bypassed, and one where the phase accumulator output is brought out to the outputs as a check.

Figure 1 shows the circuit for reading out the phase accumulator all the time. In this case, a microprocessor loads the frequency and phase registers of the NCO16. This is fairly straightforward, except the Start Logic block, which needs to be synchronous to the oscillator clock and the microprocessor interface. This has been left as an undefined function, since it is dependent on the implementation. Also note that COS0-15 are connected up, although only COS4-15 are valid in this application. The microprocessor reads the sine and cosine data busses as if they were RAMs, using the decoded address bus to select one or the other.


FIGURE 1. CIRCUIT FOR READING PHASE ACCUMULATOR OF NCO16

The timing for loading the center frequency register and seeing the output on COSO-15 and SINO-15 is shown in Figure 2. This timing is independent of whether the output data represents the phase accumulator data or the SIN/COS Generator output.


FIGURE 2. NCO16 PIPELINE DELAY
When the output of the NCO16 is to be switched back and forth between sine/cosine and the phase accumulator, a circuit such as the one shown in Figure 3 could be used. In this case, the sinusoidal output cannot be interrupted, so the phase accumulator must be read out between samples. This is possible due to the fact that the TEST signal is simply the control line for a multiplexer on the output of the SIN/COS Generator, but carries with it a limitation on the maximum possible clock rate. Since TEST is a synchronous input, the output of the NCO16 must be either driven by the SIN/COS Generator or the phase accumulator for an entire clock cycle. Therefore, the part must be driven at twice the desired speed at all times so there is a clock cycle available for TEST when necessary. Note that the processor must be driven from the same clock that generates the NCO clock in order to maintain synchronous operation. The timing is identical to that shown in Figure 2 with CLK replaced with CLK/2.



## PIPELINE DELAY THROUGH THE HSP45106

The following timing diagrams show the pipeline delays through the HSP45106 NCO16 from the time that data is applied to the inputs until the outputs are affected by the
change. The delay is shown as a number of clock cycles, with no attempt made to accurately represent the setup and hold times or the clock to output delays.


FIGURE 2. PHASE TO OUTPUT DELAY


FIGURE 3. PHASE MODULATION TO OUTPUT DELAY



## THE NCO AS A STABLE, ACCURATE SYNTHESIZER

## Low Jitter Frequency Reference

In communication and other circuits, it is often necessary to produce an accurate reference signal whose frequency and phase can be precisely controlled in real time. The Numerically Controlled Oscillator (NCO) is ideally suited for this purpose. For some applications, the output reference signal is a square wave, so the temptation is to use only the MSB of the NCO output. This is useful in low frequency applications such as motor controllers, but is inadequate for most communications tasks. This is because the zero crossings of this signal can vary by one period of the input clock from one pulse to the next, which creates an unacceptable amount of jitter in the output. For example, if the NCO is clocked at 30 MHz , the jitter is 33 nsec . For a 1 MHz square wave, this results in $12^{\circ}$ of phase jitter. The straightforward solution is to use an NCO with a much higher clock rate. This is not cost effective for applications requiring phase jitter of less than 5 nsec , however, since it requires a sample rate of 200 Mega Samples Per Second, (MSPS), which drives the user to an ECL NCO.

A much less costly circuit which solves this problem is shown in Figure 1. The output of the comparator is a square wave with much less jitter than the NCO alone. The basic idea is that the sampled sine wave output of the NCO is converted to a smooth sine wave, which is converted back to a square wave with a comparator. In the circuit shown, the comparator drives a filter, which attenuates the odd order harmonics so that the final output of the circuit is a sine wave. The upper limit on the purity of the sine wave is also much better than that of the NCO, as will be seen below.

## The primary sources of error in this circuit are:

In the NCO, spurs are classified as either AM or PM. PM spurs are due to truncation of the phase in calculating the sine and cosine. If $M=$ number of bits into the input of the Sine/Cosine Generator, the PM spur level is $-6 M+5.17 \mathrm{~dB}[1]$. The AM spurs are due to amplitude quantization on the output of the NCO. If the number of NCO output bits is N, the AM spur level is approximately equal to $-6.02 \mathrm{~N}-1.76 \mathrm{~dB}$. [1] There will also be jitter due to the clock oscillator driving the


NCO, but since it is only the short term jitter, not the long term stability of the oscillator that contributes to phase noise, this will be negligible if a reasonably good oscillator is used.

The DAC introduces additional spurs, which come from three sources: intermodulation spurs due to non-linearities in the DAC; a spur at the clock oscillator frequency due to clock feed-through; and power supply noise. The DAC also faithfully reproduces the aliases and harmonics that are unavoidable products of the NCO due to the digital nature of the output.

The filter on the output of the DAC eliminates the clock feed through, aliases due to the sampled nature of the NCO output and most of the AM spurs are eliminated with the bandpass. Spurs within the pass band are unchanged. The spectrum of the DAC output is a tone surrounded by spurs and noise in the frequency band corresponding to the pass band of the filter with negligible noise elsewhere. The area comprised of the tone, spurs and noise is known as the pedestal.

The input of the comparator is a relatively clean sine wave which the comparator converts into a square wave. This limiting action eliminates the AM spurs but has no effect on the PM spurs. For this reason, the number of bits used on the output of the NCO and the input of the DAC has little measurable effect on the output. The primary contributions to errors on the output of the comparator are the PM spurs on its input, which are passed through relatively unaffected, and power supply noise, which is attenuated by the power supply rejection of the comparator. If the filter on the input of the comparator did not remove the aliases and clock feed through, then the comparator will generate intermodulation components. This makes a good filter and a careful frequency plan essential.

If the desired output of the circuit is a sine wave rather than a square wave, the output of the comparator is filtered to extract the fundamental - that is, to suppress the odd order harmonics of the square wave signal. Note that this signal is much cleaner than the output of the first filter, since the comparator has removed the AM spurs.
The circuit shown here is often used to generate the reference tone for an indirect loop PLL synthesizer. In this case, the output of this circuit is fed into one input of a mixer, with the other input of the mixer driven by a high frequency VCO. The output of the mixer is a high frequency tone. The phase noise at the output of the mixer due to the noise in the reference circuit will be equal to the spur level of the reference circuit plus $20 * \log 10$ (output frequency/NCO frequency). For example, using the 45106 as a 5 MHz reference for a 1 GHz synthesizer, the spurs on the output of the reference would increase by $20 \log 10$ (200), so the output spur level would be $-114+46=-68 \mathrm{dBc}$ at 1 GHz . The NCO frequency resolution is 0.008 Hz at 33 MSPS , so the tuning resolution of the synthesizer is $200(0.008)=1.6 \mathrm{~Hz}$. Finer resolution can be obtained by cascading the Time Accumulator with the Phase Accumulator. (See below.)

## Extended Frequency Resolution

The phase accumulator of the HSP45106 (NCO16) is 32bits wide. This corresponds to a frequency resolution of (Sample Frequency)/2 $2^{32}$. For a 25 MSPS sample rate, this results in an output frequency resolution of 0.006 Hz . In certain applications, there is a requirement for much greater resolution. The NCO16 can address these applications using the Time Accumulator as an extension of the Phase Accumulator. Frequency resolutions of up to 64bits can be obtained in this configuration. Using the previous example of a 25 MHz clock, the frequency resolution is $25 \mathrm{MHz} / 2^{64}=1.35$ picoHertz. Using the parts in this configuration requires a small change to the external control logic: the Timer Accumulator register must be loaded over the control bus interface. This mode of operation has no effect on any of the other performance parameters, such as spurious free dynamic range, phase resolution, etc.

To configure the HSP45106 for this application, the setup shown in Figure 2. Note that the Timer Accumulator output, TICO\#, is connected to the Phase Accumulator input, PACI\#. To set the output frequency of the part, the Center Frequency Register and the Timer Accumulator must be loaded. Assuming that the Offset Register is not used, the equation for calculating the output frequency is now:


FIGURE 2. EXTENDED FREQUENCY RESOLUTION CIRCUIT

## Center Frequency =

CLK Frequency $x$ ((Center Frequency Register / $2^{32}$ )
$+\left(\right.$ Timer Accumulator Register / $2^{64}$ )
In this equation, the contents of the value in the Center Frequency Register is a two's complement number, i.e., the part tunes from -(CLK Frequency) / 2 to +(CLK Frequency) / 2. The value in the Timer Accumulator is an unsigned number.

It is unsigned because it provides the carry in to the Phase Accumulator, which is always added to the LSB of the current phase value.

The user should note that there is a flip flop between the Time Accumulator carry out and the TICO\# pin, and another flip flop between the PACI\# pin and the Phase Accumulator carry input. This will cause a two clock cycle delay between the carry out of the timer into the carry in of the accumulator. This will only have an effect on the output when the frequency register is updated; in effect, the Time Accumulator lags the Phase Accumulator by two clock cycles. If this is a concern, this can be compensated for by loading the input registers for both accumulators, then toggling ENTIREG\# two clock cycles before ENCFREG\#.

While the internal architecture of the HSP45116 NCOM and the HSP45106 NCO16 are very similar, this application works better with the NCO16 for two reasons. The first is that on the NCO16, the timer is loaded using a unique pin, rather than sharing this function with the ROM bypass line. This means that the output of the NCO16 is always valid, instead of having erroneous results on the output whenever the timer is updated. The second is that with the NCO16, the data for the various registers is downloaded into separate input registers, which can be downloaded into the operating registers with the ENXXREG\# pulses. With the NCOM, there is only one 32bit input register, which must be downloaded
into the appropriate operating register before the next value can be input into the part. In this application, it means that the user can adjust the phase between the register updates with the NCO16 but not with the NCOM.

## Example

The circuit used to verify this equation is shown in Figure 2. The clock oscillator frequency was measured at 25.24102 MHz . In order to achieve an output frequency of 1.000000 Hz , the center frequency was set to hexadecimal AA, the offset frequency set to 0, and the Timer Accumulator set to hexadecimal 28880000. A frequency counter was attached to bit 15 of the cosine output. The actual frequency out varied from 0.9999999 to 1.0000003 as the oscillator drifted with time. A more stable oscillator would yield more predictable results. Note that going through the calculations results in an output frequency of 1.0000006 Hz . The difference is due to the fact that the oscillator frequency measurement was only carried out to 7 digits, but the counter used in this example had 8 digits.

## References

[1] Cercas, Francisco A. B., Tomlinson, $M$ and Albuquerque, A. A. Designing with Digital Frequency Synthesizers, Proceedings of RF Expo East, 1990


## HISTOGRAMMING WITH A VARIABLE PIXEL INCREMENT

The HSP48410 Histogrammer/Accumulating Buffer has several modes; two of these are Histogram mode, in which the part computes the histogram of an input data stream, and bin accumulate mode, in which it computes the totals of a set of rank-ordered data. These operations work on generalized digital data, but for the purposes of this tech brief, image data will be used as an example.

In Histogram mode (Figure 1), the HSP48410 accepts pixel data on the PINO-9 bus. It uses this information as the address of its internal RAM to compute the number of pixels in an image that are at each gray level. The contents of the RAM at the given address is fed into an adder; the other input of the adder is set to all zeroes except for a one in the LSB. The output of the adder is written back into the RAM in the same location. When all pixels have been processed by the chip, the RAM contains the histogram of the image.

When placed in Bin Accumulate mode (Figure 2), the HSP48410 operates in a similar manner, except that the inputs to the adder come from the RAM and the DINO-23 input bus. In this mode, the user loads the DIN bus with the desired increment value. Since this is a synchronous input, it can be changed on a pixel by pixel basis. When the operation is finished, the completed histogram will be stored in the RAM as before.


FIGURE 1. HISTOGRAMMER MODE BLOCK DIAGRAM

Figure 3 shows an implementation of the latter function using a TMS320 for the system microprocessor. The circuit diagram and timing were derived from the TMS320C25 data sheet and the 1989 Second Generation TMS 320 User's Guide. This circuit has not yet been verified with a physical implementation.

Initially, the part is set to Bin Accumulate mode (FCT = 100). The memory is reset with FC\# (Flash Clear) prior to data processing. The input image data is latched into PINO-9, the histogram increment for that pixel is simultaneously loaded into DINO-23. The internal pipeline delays align the two sets of data internally so that the proper bit in the histogram is incremented with the right number. The SYNC signal is used to flag the beginning of the new frame of data, and stays low while image data is being fed into the part.

When one frame of image data has been processed, the histogram can be read out of the memory over the microprocessor interface. After the START\# pin is brought high, the TMS320 uses the FCTO-2 lines to configure the part for 16 bit Asynchronous mode (FCT = 111). The contents of the bins can now be read out asynchronously to the pixel clock and in random order. START\# remains high during this operation.


FIGURE 2. BIN ACCUMULATE MODE BLOCK DIAGRAM


FIGURE 3. HSP48410 CIRCUIT SHOWING INTERFACE TO TMS 320 AND DYNAMIC PIXEL INCREMENT


No. TB306 January 1994

## Harris Digital Signal Processing

## CASCADING MULTIPLE HSP45256 CORRELATORS

When multiple correlators are cascaded for longer reference data sets, the Programmable Delay is used to adjust the timing between chips so that they can be connected with no external hardware. Figure 1 shows the portions of two correlators that would be active when two 45256's are set up to perform a 1 bit, 512 tap correlation. In this case, DOUT7 of one correlator is connected to DIN7 of the next one; CASOUTO- 12 of the first part are connected to CASINO-12 of the second one. (See the HSP45256 data sheet.) Figure 2 shows the relevant portions of two Correlators which are
cascaded together; in this example, each is configured as $1 \times 256$. In the interest of clarity, the only portions shown are the final stage of the first correlator and the first stage of the second one. The data sample number at each stage for a given clock cycle is shown in the boxed in numbers. Note that the Programmable Delay of the first part is set to a delay of one (the minimum possible) and the second part is set to a delay of two. This assures that the proper samples are added in the Cascade Summer.


FIGURE 1. CIRCUIT BLOCK DIAGRAM


FIGURE 2. CASCADED CORRELATORS SHOWING RELATIVE CLOCK CYCLES.


## CORRELATION WITH MULTIBIT DATA USING THE HSP45256

For single bit data, the output of the correlator, that is, the correlation score, represents the total number of data bits that match the reference at time $n$. At time $n+1$, the data slides past the reference by one sample, a new data sample is input into the device, and the new sum is calculated. When the data matches the reference most closely, a correlation peak is obtained. Figure 1 shows a stream of data being correlated with a reference and the corresponding peak in the output score.

The maximum possible correlation score (corresponding to a perfect match) equals the number of bits in the data stream. Assuming that the reference pattern occurs only once in the data, the correlation score will build slowly until it reaches the peak. Assuming random input data, most of the time about
half of the data samples will match the reference. The minimum correlation score for a given configuration will then be one half of the peak score.

This example is ideal; the received pulse is not corrupted by noise, so correlation is perfect. In the real world, noise on the input data will lower the correlation peak, making it more difficult to determine its position in the data. Quantizing the data using more than one bit helps to alleviate this problem. In the example shown in Figure 2, two bit quantization is used to illustrate this point. In this case, calculation of the maximum possible score must take into account the bit weighting. The output scores are shown normalized to their respective maximums so that a fair comparison is achieved. Note that using more data bits sharpens the peak of the score.


FIGURE 1. CONCEPTUAL DIAGRAM OF CORRELATION OF SINGLE BIT DATA AND REFERENCE


FIGURE 2. COMPARISON OF CORRELATION USING ONE BIT AND TWO BIT DATA

## HARRIS QUALITY AND RELIABILITY

PAGE
HARRIS QUALITY ..... 10-3
INTRODUCTION ..... 10-3
THE ROLE OF THE QUALITY ORGANIZATION ..... 10-3
THE IMPROVEMENT PROCESS ..... 10-3
DESIGNING FOR MANUFACTURABILITY ..... 10-3
SPECIAL TESTING ..... 10-5
HARRIS SEMICONDUCTOR STANDARD PROCESSING FLOWS ..... 10-6
CONTROLLING AND IMPROVING THE MANUFACTURING PROCESS - SPC/DOX ..... 10-8
AVERAGE OUTGOING QUALITY (AOQ) ..... 10-9
Training ..... 10-9
Incoming Materials ..... 10-9
CALIBRATION LABORATORY ..... 10-11
MANUFACTURING SCIENCE - CAM, JIT, TPM ..... 10-11
Computer Aided Manufacturing (CAM) ..... 10-11
Just In Time (JIT) ..... 10-11
Total Productive Maintenance (TPM) ..... 10-11
HARRIS RELIABILITY ..... 10-12
PROCESS/PRODUCT/PACKAGE QUALIFICATIONS ..... 10-12
PRODUCT/PACKAGE RELIABITY MONITORS ..... 10-12
FIELD RETURN PRODUCT ANALYSIS SYSTEM ..... 10-13
FAILURE ANALYSIS LABORATORY ..... 10-16
ANALYTICAL SERVICES LABORATORY ..... 10-16
RELIABILITY FUNDAMENTALS AND CALCULATION OF FAILURE RATE ..... 10-17
Failure Rate Calculations ..... 10-17
Acceleration Factors ..... 10-18
Activation Energy ..... 10-18
TECH BRIEF 52 Electrostatic Discharge Control A Guide To Handling Integrated Circuits ..... 10-19

$$
-
$$

## Introduction

Success in the integrated circuit industry means more than simply meeting or exceeding the demands of today's market. It also includes anticipating and accepting the challenges of the future. It results from a process of continuing improvement and evolution, with perfection as the constant goal.
Harris Semiconductor's commitment to supply only top value integrated circuits has made quality improvement a mandate for every person in our work force - from circuit designer to manufacturing operator, from hourly employee to corporate executive. Price is no longer the only determinant in marketplace competition. Quality, reliability, and performance enjoy significantly increased importance as measures of value in integrated circuits.
Quality in integrated circuits cannot be added on or considered after the fact. It begins with the development of capable process technology and product design. It continues in manufacturing, through effective controls at each process or step. It culminates in the delivery of products which meet or exceed the expectations of the customer.

## The Role of the Quality Organization

The emphasis on building quality into the design and manufacturing processes of a product has resulted in a significant refocus of the role of the Quality organization. In addition to facilitating the development of SPC and DOX, Quality professionals support other continuous improvement tools such as control charts, measurement of equipment capability, standardization of inspection equipment and processes, procedures for chemical controls, analysis of inspection data and feedback to the manufacturing areas, coordination of efforts for process and product improvement, optimization of environmental or raw materials quality, and the development of quality improvement programs with vendors.
At critical manufacturing operations, process and product quality is analyzed through random statistical sampling and product monitors. The Quality organization's role is changing from policing quality to leadership and coordination of quality programs or procedures through auditing, sampling, consulting, and managing Quality Improvement projects.
To support specific market requirements, or to ensure conformance to military or customer specifications, the Quality organization still performs many of the conventional quality functions (e.g., group testing for military products or wafer lot acceptance). But, true to the philosophy that quality is everyone's job, much of the traditional on-line measurement and control of quality characteristics is where it belongs - with the people who make the product. The Quality organization is there to provide leadership and assistance in the deployment of quality techniques, and to monitor progress.

## The Improvement Process



FIGURE 1. STAGES OF STATISTICAL QUALITY TECHNOLOGY
Harris Semiconductor's quality methodology is evolving through the stages shown in Figure 1. In 1981 we embarked on a program to move beyond Stage I, and we are currently in the transition from Stage III to Stage IV, as more and more of our people become involved in quality activities. The traditional "quality" tasks of screening, inspection, and testing are being replaced by more effective and efficient methods, putting new tools into the hands of all employees. Table 1 illustrates how our quality systems are changing to meet today's needs.

## Designing for Manufacturability

Assuring quality and reliability in integrated circuits begins with good product and process design. This has always been a strength in Harris Semiconductor's quality approach. We have a very long lineage of high reliability, high performance products that have resulted from our commitment to design excellence. All Harris products are designed to meet the stringent quality and reliability requirements of the most demanding end equipment applications, from military and space to industrial and telecommunications. The application of new tools and methods has allowed us to continuously upgrade the design process.
Each new design is evaluated throughout the development cycle to validate the capability of the new product to meet the end market performance, quality, and reliability objectives.
The validation process has four major components:

1. Design simulation/optimization
2. Layout verification
3. Product demonstration
4. Reliability assessment.

## Harris Quality

TABLE 1. TYPICAL ON-LINE MANUFACTURING/QUALITY FUNCTIONS

| AREA | FUNCTION | MANUFACTURING CONTROLS | QA/QC MONITOR AUDIT |
| :---: | :---: | :---: | :---: |
| Wafer Fab | - JAN Self-Audit <br> - Environmental <br> - Room/Hood Particulates <br> - Temperature/Humidity <br> - Water Quality <br> - Product <br> - Junction Depth <br> - Sheet Resistivities <br> - Defect Density <br> - Critical Dimensions <br> - Visual Inspection <br> - Lot Acceptance <br> - Process <br> - Film Thickness <br> - Implant Dosages <br> - Capacitance Voltage Changes <br> - Conformance to Specification <br> - Equipment <br> - Repeatability <br> - Profiles <br> - Calibration <br> - Preventive Maintenance | $x$ x <br> X <br> $x$ <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X | X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> x <br> X <br> X <br> X |
| Assembly | - JAN Self-Audit <br> - Environmental <br> - Room/Hood Particulates <br> - Temperature/Humidity <br> - Water Quality <br> - Product <br> - Documentation Check <br> - Dice Inspection <br> - Wire Bond Pull Strength/Controls <br> - Ball Bond Shear/Controls <br> - Die Shear Controls <br> - Post-Bond/Pre-Seal Visual <br> - Fine/Gross Leak <br> - PIND Test <br> - Lead Finish Visuals, Thickness <br> - Solderability <br> - Process <br> - Operator Quality Performance <br> - Saw Controls <br> - Die Attach Temperatures <br> - Seal Parameters <br> - Seal Temperature Profile <br> - Sta-Bake Profile <br> - Temp Cycle Chamber Temperature <br> - ESD Protection <br> - Plating Bath Controls <br> - Mold Parameters | X X <br> x <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X | X <br> X <br> X <br> X <br> X <br> X <br> X <br> x <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X <br> X |

TABLE 1. TYPICAL ON-LINE MANUFACTURING/QUALITY FUNCTIONS (Continued)

| AREA | FUNCTION | MANUFACTURING CONTROLS | QA/QC MONITOR AUDIT |
| :---: | :---: | :---: | :---: |
| Test | - JAN Self-Audit <br> - Temperature/Humidity <br> - ESD Controls <br> - Temperature Test Calibration <br> - Test System Calibration <br> - Test Procedures <br> - Control Unit Compliance <br> - Lot Acceptance Conformance <br> - Group A Lot Acceptance | X <br> X <br> X <br> X <br> X <br> X | $\bar{x}$ <br> X <br> X |
| Probe | - JAN Self-Audit <br> - Wafer Repeat Correlation <br> - Visual Requirements <br> - Documentation <br> - Process Performance | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ | $\bar{x}$ <br> X <br> X <br> X |
| Burn-In | - JAN Self-Audit <br> - Functionality Board Check <br> - Oven Temperature Controls <br> - Procedural Conformance | $\begin{aligned} & x \\ & x \end{aligned}$ | $\bar{x}$ $x$ |
| Brand | - JAN Self-Audit <br> - ESD Controls <br> - Brand Permanency <br> - Temperature/Humidity <br> - Procedural Conformance | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | X <br> $X$ <br> x <br> X |
| QCI Inspection | - JAN Self-Audit <br> - Group B Conformance <br> - Group C and D Conformance |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |

Harris designers have an extensive set of very powerful Computer-Aided Design (CAD) tools to create and optimize product designs (see Table 2).

TABLE 2. HARRIS I.C. DESIGN TOOLS

| DESIGN STEP | PRODUCTS |  |
| :--- | :--- | :--- |
|  | ANALOG | DIGITAL |
| Functional <br> Simulation | Cds Spice | Cds Spice <br> Verilog |
| Parametric <br> Simulation | Cds Spice <br> Monte Carlo | Cds Spice |
| Schematic Capture | Cadence | Cadence |
| Functional Checking | Cadence | Cadence |
| Rules Checking | Cadence | Cadence |
| Parasitic Extraction | Cadence | Cadence |

## Special Testing

Harris Semiconductor offers several standard screen flows to support a customer's need for additional testing and reliability assurance. These flows include environmental stress testing, burn-in, and electrical testing at temperatures other than $+25^{\circ} \mathrm{C}$. The flows shown on pages 9.6 and $9-7$ indicate the Harris standard processing flows for a Commercial Linear part in PDIP Package. In addition, Harris can supply products tested to customer specifications both for electrical requirements and for nonstandard environmental stress screening. Consult your field sales representative for details.

## Harris Semiconductor Standard Processing Flows


(1) Example for a PDIP Package Part


TABLE 3. SUMMARIZING CONTROL APPLICATIONS

| FAB |  |  |
| :---: | :---: | :---: |
| - Diffusion <br> - Junction Depth <br> - Sheet Resistivities <br> - Oxide Thickness <br> - Implant Dose Calibration <br> - Uniformity | - Thin Film <br> - Film Thickness <br> - Uniformity <br> - Refractive Index <br> - Film Composition | - Photo Resist <br> - Critical Dimension <br> - Resist Thickness <br> - Etch Rates <br> - Measurement Equipment <br> - Critical Dimension <br> - Film Thickness <br> - 4 Point Probe <br> - Ellipsometer |
| ASSEMBLY |  |  |
| - Pre-Seal <br> - Die Prep Visuals <br> - Yields <br> - Die Attach Heater Block <br> - Die Shear <br> - Wire Pull <br> - Ball Bond Shear <br> - Saw Blade Wear <br> - Pre-Cap Visuals | - Post-Seal <br> - Internal Package Moisture <br> - Tin Plate Thickness <br> - PIND Defect Rate <br> - Solder Thickness <br> - Leak Tests <br> - Module Rm. Solder Pot Temp. <br> - Seal <br> - Temperature Cycle | - Measurement <br> - XRF <br> - Radiation Counter <br> - Thermocouples <br> - GM-Force Measurement |
| TEST |  |  |
|  | - Handlers/Test System <br> - Defect Pareto Charts <br> - Lot \% Defective <br> - ESD Failures per Month | - Monitor Failures <br> - Lead Strengthening Quality <br> - After Burn-In PDA |
| OTHER |  |  |
| - IQC <br> - Vendor Performance <br> - Material Criteria <br> - Quality Levels | - Environment <br> - Water Quality <br> - Clean Room Control <br> - Temperature <br> - Humidity | - IQC MeasurementAnalysis <br> - XRF <br> - ADE <br> - 4 Point Probe <br> - Chemical Analysis Equipment |

## Controlling and Improving the Manufacturing Process - SPC/DOX

Statistical process control (SPC) is the basis for quality control and improvement at Harris Semiconductor. Harris manufacturing people use control charts to determine the normal variabilities in processes, materials, and products. Critical process variables and performance characteristics are measured and control limits are plotted on the control charts. Appropriate action is taken if the charts show that an operation is outside the process control limits or indicates a nonrandom pattern inside the limits. These same control charts are powerful tools for use in reducing variations in processing, materials, and products. Table 3 lists some typical manufacturing applications of control charts at Harris Semiconductor.
SPC is important, but still considered only part of the solution. Processes which operate in statistical control are not always capable of meeting engineering requirements. The conventional way of dealing with this in the semiconductor industry has been to implement $100 \%$ screening or inspection steps to remove defects, but these techniques are insufficient to meet today's demands for the highest reliability and perfect quality performance.
Harris still uses screening and inspection to "grade" products and to satisfy specific customer requirements for burn-in, multiple temperature test insertions, environmental screening, and visual inspection as value-added testing options. However, inspection and screening are limited in their ability to
reduce product defects to the levels expected by today's buyers. In addition, screening and inspection have an associated expense, which raises product cost. (See Table 4).

TABLE 4. APPROACH AND IMPACT OF STATISTICAL QUALITY TECHNOLOGY

|  | STAGE | APPROACH | IMPACT |
| :---: | :---: | :---: | :---: |
| 1 | Product Screening | - Stress and Test <br> - Defective Prediction | - Limited Quality <br> - Costly <br> - After-The-Fact |
| II | Process Control | - Statistical Process Control <br> - Just-In-Time Manufacturing | - Identifies Variability <br> - Reduces Costs <br> - Real Time |
| III | Process Optimization | - Design of Experiments <br> - Process Simulation | - Minimizes Variability <br> - Before-The-Fact |
| IV | Product Optimization | - Design for Producibility <br> - Product Simulation | - Insensitive to Variability <br> - Designed-In Quality <br> - Optimal Results |

Harris engineers are, instead, using Design of Experiments (DOX), a scientifically disciplined mechanism for evaluating and implementing improvements in product processes, materials, equipment, and facilities. These improvements are aimed at reducing the number of defects by studying the key variables controlling the process, and optimizing the procedures or design to yield the best result. This approach is a more time-consuming method of achieving quality perfection, but a better product results from the efforts, and the basic causes of product nonconformance can be eliminated.
SPC, DOX, and design for manufacturability, coupled with our 100\% test flows, combine in a product assurance program that delivers the quality and reliability performance demanded for today and for the future.

## Average Outgoing Quality (AOQ)

Average Outgoing Quality is a yardstick for our success in quality manufacturing. The average outgoing electrical defective is determined by randomly sampling units from each lot and is measured in parts per million (PPM). The current procedures and sampling plans outlined in JEDEC STD 16, MIL-STD-883 and MIL-I-38535 are used by our quality inspectors.
The focus on this quality parameter has resulted in a continuous improvement to less than 100 PPM, and the goal is to continue improvement toward 0 PPM.

## Training

The basis of a successful transition from conventional quality programs to more effective, total involvement is training. Extensive training of personnel involved in product manufacturing began in 1984 at Harris, with a comprehensive devel-
opment program in statistical methods. Using the resources of Harris statisticians, private consultants, and internally developed programs, training of engineers, supervisors, and operators/technicians has been an ongoing activity in Harris Semiconductor.
Over the past years, Harris has also deployed a comprehensive training program for hourly operators and supervisors in job requirements and functional skills. All hourly manufacturing employees participate (see Table 5).

## Incoming Materials

Improving the quality and reducing the variability of critical incoming materials is essential to product quality enhancement, yield improvement, and cost control. With the use of statistical techniques, the influence of silicon, chemicals, gases and other materials on manufacturing is highly measurable. Current measurements indicate that results are best achieved when materials feeding a statistically controlled manufacturing line have also been produced by statistically controlled vendor processes.
To assure optimum quality of all incoming materials, Harris has initiated an aggressive program, linking key suppliers with our manufacturing lines. This user-supplier network is the Harris Vendor Certification process by which strategic vendors, who have performance histories of the highest quality, participate with Harris in a lined network; the vendor's factory acts as if it were a beginning of the Harris production line. SPC seminars, development of open working relationships, understanding of Harris' manufacturing needs and vendor capabilities, and continual improvement programs are all part of the certification process. The sole use of engineering limits no longer is the only quantitative requirement of incoming materials.

TABLE 5. SUMMARY OF TRAINING PROGRAMS

| COURSE | AUDIENCE | TOPICS COVERED |
| :--- | :--- | :--- |
| SPC, Basic | Manufacturing Operators, <br> Non-Manufacturing <br> Personnel | Harris Philosophy of SPC, Statistical Definitions, Statistical Calculations, <br> Problem Analysis Tools, Graphing Techniques, Control Charts |
| SPC, Intermediate | Manufacturing Supervisors, <br> Technicians | Harris Philosophy of SPC, Statistical Definitions, Statistical Calculations, <br> Problem Analysis Tools, Graphing Techniques, Control Charts, Distributions, <br> Measurement Process Evaluation, Introduction to Capability |
| SPC, Advanced | Manufacturing Engineers, <br> Manufacturing Managers | Harris Philosophy of SPC, Statistical Definitions, Statistical Calculations, <br> Problem Analysis Tools, Graphing Techniques, Control Charts, Distributions, <br> Measurement Process Evaluation, Advanced Control Charts, Variance Com- <br> ponent Analysis, Capability Analysis |
| Design of Experiments <br> (DOX) | Engineers, Managers | Factorial and Fractional Designs, Blocking Designs, Nested Models, Analysis <br> of Variance, Normal Probability Plots, Statistical Intervals, Variance Compo- <br> nent Analysis, Multiple Comparison Procedures, Hypothesis Testing, Model <br> Assumptions/Diagnostics |
| Regression | Engineers, Managers | Simple Linear Regression, Multiple Regression, Coefficient Interval Estima- <br> tion, Diagnostic Tools, Variable Selection Techniques |
| Response Surface <br> Methods (RSM) | Engineers, Managers | Steepest Ascent Methods, Second Order Models, Central Composite De- <br> signs, Contour Plots, Box-Behnken Designs |

Specified requirements include centered means, statistical control limits, and the requirement that vendors deliver their products from their own statistically evaluated, in-control manufacturing processes.

In addition to the certification process, Harris has worked to promote improved quality in the performance of all our qualified vendors who must meet rigorous incoming inspection criteria (see Table 6).

TABLE 6. INCOMING QUALITY CONTROL MATERIAL QUALITY CONFORMANCE

| MATERIAL | INCOMING INSPECTIONS | VENDOR DATA REQUIREMENTS |
| :---: | :---: | :---: |
| Silicon | - Resistivity <br> - Crystal Orientation <br> - Dimensions . <br> - Edge Conditions <br> - Taper <br> - Thickness <br> - Total Thickness Variation <br> - Backside Criteria <br> - Oxygen <br> - Carbon | - Equipment Capability Control Charts <br> - Oxygen <br> - Resistivity <br> - Control Charts Related to <br> - Enhanced Gettering <br> - Total Thickness Variation <br> - Total Indicated Reading <br> - Particulates <br> - Certificated of Analysis for all Critical Parameters <br> - Control Charts from On-Line Processing <br> - Certificate of Conformance |
| Chemicals/Photoresists/ Gases | - Chemicals <br> - Assay <br> - Major Contaminants <br> - Molding Compounds <br> - Spiral Flow <br> - Thermal Characteristics <br> - Gases <br> - Impurities <br> - Photoresists <br> - Viscosity <br> - Film Thickness <br> - Solids <br> - Pinholes | - Certificate of Analysis on all Critical Parameters <br> - Certificate of Conformance <br> - Control Charts from On-Line Processing <br> - Control Charts <br> - Assay <br> - Contaminants <br> - Water <br> - Selected Parameters <br> - Control Charts <br> - Assay <br> - Contaminants <br> - Control Charts on <br> - Photospeed <br> - Thickness <br> - UV Absorbance <br> - Filterability <br> - Water <br> - Contaminants |
| Thin Film Materials | - Assay <br> - Selected Contaminants | - Control Charts from On-Line Processing <br> - Control Charts <br> - Assay <br> - Contaminants <br> - Dimensional Characteristics <br> - Certificate of Analysis for all Critical Parameters <br> - Certificate of Conformance |
| Assembly Materials | - Visual Inspection <br> - Physical Dimension Checks <br> - Glass Composition <br> - Bondability <br> - Intermetallic Layer Adhesion <br> - Ionic Contaminants <br> - Thermal Characteristics <br> - Lead Coplanarity <br> - Plating Thickness <br> - Hermeticity | - Certificate of Analysis <br> - Certificate of Conformance <br> - Process Control Charts on Outgoing Product Checks and In-Line Process Controls |

## Calibration Laboratory

Another important resource in the product assurance system is a calibration lab in each Harris Semiconductor operation site. These labs are responsible for calibrating the electronic, electrical, electro/mechanical, and optical equipment used in both production and engineering areas. The accuracy of instruments used at Harris is traceable to a national standards. Each lab maintains a system which conforms to the current revision of MIL-STD-45662, "Calibration System Requirements."

Each instrument requiring calibration is assigned a calibration interval based upon stability, purpose, and degree of use. The equipment is labeled with an identification tag on which is specified both the date of the last calibration and of the next required calibration. The Calibration Lab reports on a regular basis to each user department. Equipment out of calibration is taken out of service until calibration is performed. The Quality organization performs periodic audits to assure proper control in the using areas. Statistical procedures are used where applicable in the calibration process.

## Manufacturing Science - CAM, JIT, TPM

In addition to SPC and DOX as key tools to control the product and processes, Harris is deploying other management mechanisms in the factory. On first examination, these tools appear to be directed more at schedules and capacity. However, they have a significant impact on quality results.

## Computer Aided Manufacturing (CAM)

CAM is a computer based inventory and productivity management tool which allows personnel to quickly identify production line problems and take corrective action. In addition, CAM improves scheduling and allows Harris to more quickly respond to changing customer requirements and aids in managing work in process (WIP) and inventories.
The use of CAM has resulted in significant improvements in many areas. Better wafer lot tracking has facilitated a number of process improvements by correlating yields to process variables. In several places CAM has greatly improved capacity utilization through better planning and scheduling. Queues have been reduced and cycle times have been shortened - in some cases by as much as a factor of 2.

The most dramatic benefit has been the reduction of WIP inventory levels, in one area by $500 \%$. This results in fewer lots in the area and a resulting quality improvement. In wafer fab, defect rates are lower because wafers spend less time in production areas awaiting processing. Lower inventory also improves morale and brings a more orderly flow to the area. CAM facilitates all of these advantages.

## Just In Time (JIT)

The major focus of JIT is cycle time reduction and linear production. Significant improvements in these areas result in large benefits to the customer. JIT is a part of the Total Quality Management philosophy at Harris and includes Employee Involvement, Total Quality Control, and the total elimination of waste.

Some key JIT methods used for improvement are sequence of events analysis for the elimination of non-value added activities, demand/pull to improve production flow, TQC check points and Employee Involvement Teams using root cause analysis for problem solving.

JIT implementations at Harris Semiconductor have resulted in significant improvements in cycle time and linearity. The benefits from these improvements are better on time delivery, improved yield, and a more cost effective operation.

JIT, SPC, and TPM are complementary methodologies and used in conjunction with each other create a very powerful force for manufacturing improvement.

## Total Productive Maintenance (TPM)

TPM or Total Productive Maintenance is a specific methodology which utilizes a definite set of principles and tools focusing on the improvement of equipment utilization. It focuses on the total elimination of the six major losses which are equipment failures, setup and adjustment, idling and minor stoppages, reduced speed, process defects, and reduced yield. A key measure of progress within TPM is the overall equipment effectiveness which indicates what percentage of the time is a particular equipment producing good parts. The basic TPM principles focus on maximum equipment utilization, autonomous maintenance, cross functional team involvement, and zero defects. There are some key tools within the TPM technical set which have proven to be very powerful to solve long standing problems. They are initial clean, P-M analysis, condition based maintenance, and quality maintenance.

Utilization of TPM has shown significant increases in utilization on many tools across the Sector and is rapidly becoming widespread and recognized as a very valuable tool to improve manufacturing competitiveness.

The major benefits of TPM are capital avoidance, reduced costs, increased capability, and increased quality. It is also very compatible with SPC techniques since SPC is a good stepping stone to TPM implementation and it is in turn a good stepping stone to JIT because a high overall equipment effectiveness guarantees the equipment to be available and operational at the right time as demanded by JIT.

## Harris Reliability

The reliability operations for Harris Semiconductor are consolidated into three locations; in Palm Bay, Florida, and Research Triangle Park, North Carolina, for integrated circuits products, and Mountaintop, Pennsylvania for Power Discrete Products. This consolidation brought the reliability organizations together to form a team that possesses a broad cross section of expertise in:

- Custom Military
- Automotive ASICs
- Harsh Environment Plastic Packaging
- Advanced Methods for Design for Reliability (DFR)
- Strength in Power Semiconductor
- Chemical/Surface Analysis Capabilities

The reliability focus is customer satisfaction (external and internal) and is accomplished through the development of standards, performance metrics and service systems. These major systems are summarized below:

- A process and product development system which emphasizes getting new products to market over product design. Uses empowered cross functional development teams.
- Standard test vehicles ( 96 in all) for process characterization of wearout failure mechanisms using conventional stresses (for modeling FITs/MTTF) and wafer level reliability characterization during development.
- Common qualification standards and philosophy for all sites and developments.
- Matrix monitor standard - a reliability monitoring system for products in production to insure ongoing reliability and verification of continuous improvement.
- Field return failure analysis system deployed world wide to track and expedite root cause analysis and irreversible corrective actions in a timely manner for our customers. The system is called by the team name PFAST, Product Failure Analysis Solution Team. Failure analysis sites are located in Brussels, Mountaintop, Palm Bay, Singapore, Kuala Lumpur, and Tokyo. In order to optimize our response time to the customer all locations are networked for optimum communication, trend analysis, and performance tracking.

Integrated circuits reliability home base is in Palm Bay, Florida. This new facility has consolidated the reliability organization of the standard products divisions reliability group from Palm Bay, Florida; Somerville, New Jersey; Santa Clara, California, and the Military and Aerospace Division in Palm Bay, Florida. This facility contains

- A 9,000 square foot reliability analysis laboratory,
- An 8,000 square foot reliability stress testing facility,
- A 5,000 square foot analytical (chemistry/surface analysis) laboratory,
- A 3,000 square foot of engineering office space.

The facilities are well equipped and manned with highly trained and disciplined analysts. The reliability facilities are JAN certified and certified by a host of customers including major automotive and telecommunications companies.

## Process/Product/Package Qualifications

Qualification activities at Harris begin with the in-depth qualification of new wafer processes. These process qualifications focus on the use of test vehicles to characterize wearout mechanisms for each process. These data are used to establish design ground rules for each process to eliminate wearout failure during the useful life of the product. Products designed within the established ground rules are qualified individually prior to introduction. New package configurations are qualified individually prior to being available for new products. Harris qualification procedures are specified via controlled documentation.

## Product/Package Reliability Monitors

Many of the accelerated stress-tests used during initial reliability qualification are also employed during the routine monitoring of standard production product. Harris' continuing reliability monitoring program consists of three groups of stress tests, labeled Matrix I, II and III. As an example, Table 7 outlines the Matrix tests used to monitor plastic packaged CMOS Logic ICs in Harris' Malaysia assembly plant, where each wafer fab technology is sampled weekly for both Matrix I and II. Matrix I consists of highly accelerated, short duration ( 48 hours or less) tests, which provide real-time feedback on product reliability. Matrix II consists of the more traditional, longer term stress-tests, which are similar to those used for product qualification. Finally, Matrix III, performed monthly on each package style, monitors the mechanical reliability aspects of the package. Any failures occurring on the Matrix monitors are fully analyzed and the failure mechanisms identified, with corrective actions obtained from Manufacturing and Engineering. This information along with all of the test results are routinely transmitted to a central data base in Reliability Engineering, where failure rate trends are analyzed and tracked on an ongoing basis. These data are used to drive product improvements, so as to ensure that failure rates are continuously being reduced over time.

TABLE 7. PLASTIC PACKAGED CMOS LOGIC ICS MALAYSIA RELIABILITY MONITORING TESTS.

MATRIX I

| TEST | CONDITIONS | DURATION | SAMPLE |
| :--- | :---: | :---: | :---: |
| Bias Life | $+175^{\circ} \mathrm{C}$ | 48 Hours | 40 |
| HAST | $+145^{\circ} \mathrm{C}, 85 \% \mathrm{RH}$ | 20 Hours | 40 |

TABLE 7. PLASTIC PACKAGED CMOS LOGIC ICS MALAYSIA RELIABILITY MONITORING TESTS (Continued)

MATRIX II

| TEST | CONDITIONS | DURATION | SAMPLE |
| :--- | :---: | :---: | :---: |
| Bias Life | $+125^{\circ} \mathrm{C}$ | 1000 Hours | 50 |
| Dynamic Life | $+125^{\circ} \mathrm{C}$ | 1000 Hours | 50 |
| Biased Humidity | $+85^{\circ} \mathrm{C}, 85 \%$ RH | 1000 Hours | 50 |
| Autoclave | $15 \mathrm{PSIG},+121^{\circ} \mathrm{C}$, <br> $100 \% ~ R H$ | 192 Hours | 50 |
| Storage Life | $+150^{\circ} \mathrm{C}$ | 1000 Hours | 50 |
| Temp. Cycle | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | 1000 Cycles | 50 |
| Thermal Shock | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | 1000 Cycles | 50 |

MATRIX III

| TEST | CONDITIONS | SAMPLE |
| :--- | :---: | :---: |
| Solderability | MIL-STD 883/2003 | 15 |
| Lead Fatigue | MIL-STD 883/2004 | 15 |
| Brand Adhesion | MIL-STD 883/2015 | 20 |
| Flammability | (UL-94 Vertical Burn) | 5 |

## Field Return Product Analysis System

The purpose of this system is to enable Harris' Field Sales and Quality operations to properly route, track and respond to our customers' needs as they relate to product analysis.
The Product Failure Analysis Solution Team (PFAST) consists of the group of people who must act together to provide timely, accurate and meaningful results to customers on units returned for analysis. This team includes the salesman or applications engineer who gets the parts from the customer, the PFAST controller who coordinates the response, the Product or Test Engineering people who obtain characterization and/or test data, the analysts who failure analyze the units, and the people who provide the ultimate corrective action. It is the coordinated effort of this team, through the system described in this document that will drive the Customer responsiveness and continuous improvement that will keep Harris on the forefront of the semiconductor business.

The system and procedures define the processing of product being returned by the customer for analysis performed by Product Engineering, Reliability Failure Analysis and/or Quality Engineering. This system is designed for processing "sample" returns, not entire lot returns or lot replacements.
The philosophy is that each site analyzes its own product. This applies the local expertise to the solutions and helps toward the goal of quick turn time.
Goals: quick, accurate response, uniform deliverable (consistent quality) from each site, traceability.

The PFAST system is summarized in the following steps:

1) Customer calls the sales rep about the unit(s) to return.
2) Fill out PFAST Action Request - see the PFAST form in this section. This form is all that is required to process a Field Return of samples for failure analysis. This form contains essential information necessary to perform root cause analysis. (See Figure 2).
3) The units must be packaged in a manner that prevents physical damage and prevents ESD. Send the units and PFAST form to the appropriate PFAST controller. This location can be determined at the field sales office or rep using "look-up" 'tables in the PFAST document.
4) The PFAST controller will log the units and route them to ATE testing for data log.
5) Test results will be reviewed and compared to customer complaint and a decision will be made to route the failure to the appropriate analytical group.
6) The customer will be contacted with the ATE test results and interim findings on the analysis. This may relieve a line down situation or provide a rapid disposition of material. The customer contact is valuable in analytical process to insure root cause is found.
7) A report will be written and sent directly to the customer with copies to sales, rep, responsible individuals with corrective actions and to the PFAST controller so that the records will capture the closure of the cycle.
8) Each report will contain a feedback form (stamped and preaddressed) so that the PFAST team can assess their performance based on the customers assessment of quality and cycle time.
9) The PFAST team objectives are to have a report in the customers hands in 28 days, or 14 days based on agreements. Interim results are given real-time.


FIGURE 2. PFAST ACTION REQUEST

## INSTRUCTIONS FOR COMPLETING PFAST ACTION REQUEST FORM

The purpose of this form is to help us provide you with a more accurate, complete, and timely response to failures which may occur. Accurate and complete information is essential to ensure that the appropriate corrective action can be implemented. Due to this need for accurate and complete information, requests without a completed PFAST Action Request form will be returned.

## Source of Problem:

This section requests the product flow leading to the failure. Mark an " X " in the appropriate boxes up to and including the step which detected the failure. Also mark an " X " in the appropriate box under ARE RESULTS REPRESENTATIVE OF PREVIOUS LOTS? to indicate whether this is a rare failure or a repeated problem.

Example 1. No incoming electrical test was performed, the units were installed onto boards, the boards functioned correctly for two hours and then 1 unit failed. The customer rarely has a failure due to this Harris device.
SOURCE OF PROBLEM
(Enver the sequence of evests in the bosee provided)

1. Visual/mbchanical. - Describe
2. incoming test - 100\% TESTED No. Tested $\qquad$
$\qquad$ Example 2. 100 out of the 500 units shipped were tested at incoming and all passed. The units were installed into boards and the boards passed. The boards were installed into the system and the system failed immediately when turned on. There were 3 system failures due to this part. The customer frequently has failures of this Harris device. The 3 units were not retested at incoming.


## Action Requested by Customer.

This section should be completed with the customer's expectations. This information is essential for an appropriate response.

## Reason for Electrical Reject:

This section should be completed if the type of failure could be identified. If this information is contained in attached customer correspondence there is no need to transpose onto the PFAST Action Request form.

## PFAST REQUIREMENTS

The value of returning failing products is in the corrective actions that are generated. Failure to meet the following requirements can cause an erroneous conclusion and corrective action; therefore, failure to meet these requirements will result in the request being returned. Contact the local PFAST Coordinator if you have any questions.

Units with conformal coating should include the coating manufacturer and model. This is requested since the coating must be removed in order to perform electrical or hermeticity testing.

1) Units must be returned with proper ESD protection (ESD-safe shipping tubes within shielding box/bag or inserted into conductive foam within shielding box/bag). No tape, paper bags, or plastic bags should be used. This requirement ensures that the devices are not damaged during shipment back to Harris.
2) Units must be intact (lid not removed and at least part of each package lead present). This requirement is in place since the parts must be intact in order to perform electrical test. Also, opening the package can remove evidence of the cause for failure and lead to an incorrect conclusion.
3) Programmable parts (ROMs, PROMS, UVEPROMs, and EEPROMs) must include a master unit with the same pattern. This requirement is to provide the pattern so all failing locations can be identified. A master unit is required if a failure analysis is requested.

FIGURE 2. PFAST ACtion request (Continued)

## Failure Analysis Laboratory

The Failure Analysis Laboratory's capabilities encompass the isolation and identification of all failure modes/failure mechanisms, preparing comprehensive technical reports, and assigning appropriate corrective actions. Research vital to understanding the basic physics of the failure is also undertaken.

Failure analysis is a method of enhancing product reliability and determining corrective action. It is the final and crucial step used to isolate potential reliability problems that may have occurred during reliability stressing. Accurate analysis results are imperative to assess effective corrective actions. To ensure the integrity of the analysis, correlation of the failure mechanism to the initial electrical failure is essential.

A general failure analysis procedure has been established in accordance with the current revision of MIL-STD-883, Section 5003. The analysis procedure was designed on the premise that each step should provide information on the failure without destroying information to be obtained from subsequent steps. The exact steps for an analysis are determined as the situation dictates. (See Figures 3 and 4). Records are maintained by laboratory personnel and contain data, the failure analyst's notes, and the formal Product Analysis Report.

## Analytical Services Laboratory

Harris facilities, engineering, manufacturing, and product assurance are supported by the Analytical Services Laboratory. Organized into chemical or microbeam analysis methodology, staff and instrumentation from both labs cooperate in fully integrated approaches necessary to

FIGURE 3. NON-DESTRUCTIVE
complete analytical studies. The capabilities of each area are shown below.

SPECTROSCOPIC METHODS: Colorimetry, Optical Emission, Ultraviolet Visible, Fourier Transform-Infrared, Flame Atomic Absorption, Furnace Organic Carbon Analyzer, Mass Spectrometer.

## CHROMATOGRAPHIC METHODS: Gas Chromatography, Ion Chromatography.

THERMAL METHODS: Differential Scanning Colorimetry, Thermogravimetric Analysis, Thermomechanical Analysis.
PHYSICAL METHODS: Profilometry, Microhardness, Rheometry.

CHEMICAL METHODS: Volumetric, Gravimetric, Specific Ion Electrodes.
ELECTRON MICROSCOPE: Transmission Electron Microscopy, Scanning Electron Microscope.

X-RAY METHODS: Energy Dispersive X-ray Analysis (SEM), Wavelength Dispersive X-ray Analysis (SEM), X-ray Fluorescence Spectrometry, X-ray Diffraction Spectrometry.

SURFACE ANALYSIS METHODS: Scanning Auger Microprobe, Electron Spectroscopy/Chemical Analysis, Secondary Ion Mass Spectrometry, Ion Scattering Spectrometry, Ion Microprobe.

The department also maintains ongoing working arrangements with commercial, university, and equipment manufacturers' technical service laboratories, and can obtain any materials analysis in cases where instrumental capabilities are not available in our own facility.


FIGURE 4. DESTRUCTIVE

## Reliability Fundamentals and Calculation of Failure Rate

Table 8 below defines some of the more important terminology used in describing the lifetime of integrated circuits.
Of prime importance is the concept of "failure rate" and the calculation thereof.

## Failure Rate Calculations

Reliability data may be composed of several different failure mechanisms and the combining of potentially diverse failure rates into one comprehensive failure rate is desired. The failure rate calculation is complicated because the failure mechanisms are thermally activated at differing rates. Additionally, this data is usually obtained on a number of life tests performed at unique stress temperatures. The equation below accounts for these considerations along with a statistical factor to obtain the upper confidence level (UCL) for the resulting failure rate.

$$
\lambda=\left[\sum_{i=1}^{\beta} \frac{x_{i}}{\sum_{j=1}^{k} T D H_{j} A F_{i j}}\right] \bullet \frac{M \times 10^{9}}{\sum_{i=1}^{\beta} x_{i}}
$$

where,
$\lambda=$ failure rate in FITs (Number fails in $10^{9}$ device hours)
$\beta=\#$ of distinct possible failure mechanisms
$k=\#$ of life tests being combined
$x_{i}=\#$ of failures for a given failure mechanism $i=1,2, \ldots \beta$
$\mathrm{TDH}_{\mathrm{j}}=$ Total device hours of test time (unaccelerated) for Life Test $\mathrm{j}, \mathrm{j}=1,2,3, \ldots \mathrm{k}$
$A F_{i j}=$ Acceleration factor for appropriate failure mechanism $i=1,2, \ldots k$
$M=\frac{x^{2}(\alpha, 2 r+2)}{2}$ where, $X^{2}=$ chi square factor for $2 r+2$ degrees of freedom $r=$ total number of failures $\left(\Sigma \mathrm{x}_{\mathrm{i}}\right)$ $\alpha=$ risk associated with UCL;
i.e. $\alpha=(100-U C L(\%)) / 100$

In the failure rate calculation, Acceleration Factors (AFij) are used to derate the failure rate from the thermally accelerated life test conditions to a failure rate indicative of actual use temperature. Although no standard exists, a temperature of $+55^{\circ} \mathrm{C}$ has been popular. Harris Semiconductor Reliability Reports will derate to $+55^{\circ} \mathrm{C}$ and will express failure rates at $60 \%$ UCL. Other derating temperatures and UCLs are available upon request.

TABLE 8. FAILURE RATE PRIMER

| TERMS | DEFINITIONS/DESCRIPTION |
| :--- | :--- |
| Failure Rate $\lambda$ | Measure of failure per unit of time. The failure rate typically decreases slightly over <br> early life, and then becomes relatively constant over time. The on set of wearout will <br> show an increasing failure rate, which should occur well beyond useful life. The useful <br> life failure rate is based on the exponential life distribution |
| FIT (Failure in Time) | Measure of failure rate in $10^{9}$ device hours; e.g., 1 FIT $=1$ failure in $10^{9}$ device hours, <br> $100 \mathrm{FITS}=100$ failure in $10^{9}$ device hours, etc. |
| Device Hours | The summation of the number of units in operation multiplied by the time of operation. |
| MTTF (Mean Time To Failure) | Mean of the life distribution for the population of devices under operation or expected <br> lifetime of an individual, MTTF = $1 / \lambda$, which is the time where $63.2 \%$ of the population <br> has failed. Exampled: For $\lambda=10$ FiTS (or $10 \mathrm{E}-9 / \mathrm{Hr}$.), MTTF $=1 / \lambda=100$ million hours. |
| Confidence Level (or Limit) | Probability level at which population failure rate estimates are derived from sample life <br> test: 10 FITs at $95 \%$ UCL means that the population failure rate is estimated to be no <br> more than 10 FITs with $95 \%$ certainty. The upper limit of the confidence interval is <br> used. |
| Acceleration Factor (AF) | A constant derived from experimental data which relates the times to failure at two <br> different stresses. The AF allows extrapolation of failure rates from accelerated test <br> conditions to use conditions. |

## Acceleration Factors

Acceleration factor is determined from the Arrhenius Equation. This equation is used to describe physiochemical reaction rates and has been found to be an appropriate model for expressing the thermal acceleration of semiconductor failure mechanisms.

$$
A F=\operatorname{EXP}\left[\frac{E_{a}}{k}\left(\frac{1}{T_{\text {use }}}-\frac{1}{T_{\text {stress }}}\right)\right]
$$

where,

$$
\begin{aligned}
\mathrm{AF} & =\text { Acceleration Factor } \\
\mathrm{E}_{\mathrm{a}} & =\text { Thermal Activation Energy }(\text { See Table } 9) \\
\mathrm{k} & =\text { Boltzmann's Constant }\left(8.63 \times 10^{-5} \mathrm{eV} /{ }^{\circ} \mathrm{K}\right)
\end{aligned}
$$

Both $T_{\text {use }}$ and $T_{\text {stress }}$ (in degrees Kelvin) include the internal temperature rise of the device and therefore represent the junction temperature.

## Aćtivation Energy

The Activation Energy ( $E_{\mathrm{a}}$ ) of a failure mechanism is determined by performing at least two tests at different levels of stress (temperature and/or voltage). The stresses will provide the time to failure ( $\mathrm{t}_{\mathrm{t}}$ ) for the two (or more) populations thus allowing the simultaneous solution for the activation energy as follows:

$$
\ln \left(t_{11}\right)=C+\frac{E_{a}}{k T_{1}} \quad \ln \left(t_{t_{2}}\right)=C+\frac{E_{a}}{k T_{2}}
$$

By subtracting the two equations, and solving for the activation energy, the following equation is obtained:

$$
E_{a}=\frac{k\left[\ln \left(t_{1}\right)-\ln \left(t_{2}\right)\right]}{(1 / T 1-1 / T 2)}
$$

where,

$$
\begin{aligned}
\mathrm{E}_{\mathrm{a}} & =\text { Thermal Activation Energy (See Table } 9) \\
\mathrm{k} & =\text { Boltzmann's Constant }\left(8.63 \times 10^{-5} \mathrm{eV} / \mathrm{K}\right) \\
\mathrm{T}_{1}, \mathrm{~T}_{2} & =\text { Life test temperatures in degrees Kelvin }
\end{aligned}
$$

TABLE 9. FAILURE MECHANISM

| FAILURE MECHANISM | ACTIVATION ENERGY | SCREENING AND TESTING METHODOLOGY | CONTROL METHODOLOGY |
| :---: | :---: | :---: | :---: |
| Oxide Defects | $0.3-0.5 \mathrm{eV}$ | High temperature operating life (HTOL) and voltage stress. Defect density test vehicles. | Statistical Process Control of oxide parameters, defect density control, and voltage stress testing. |
| Silicon Defects (Bulk) | $0.3-0.5 \mathrm{eV}$ | HTOL \& voltage stress screens. | Vendor statistical Quality Control programs, and Statistical Process Control on thermal processes. |
| Corrosion | 0.450 V | Highly accelerated stress testing (HAST) | Passivation dopant control, hermetic seal control, improved mold compounds, and product handling. |
| Assembly Defects | $0.5-0.7 \mathrm{eV}$ | Temperature cycling, temperature and mechanical shock, and environmental stressing. | Vendor Statistical Quality Control programs, Statistical Process Control of assembly processes, proper handling methods. |
| Electromigration <br> - Al Line <br> - Contact | $\begin{aligned} & 0.6 \mathrm{eV} \\ & 0.9 \mathrm{eV} \end{aligned}$ | Test vehicle characterizations at highly elevated temperatures. | Design ground rules, wafer process statistical process steps, photoresist, metals and passivation |
| Mask Defects/ <br> Photoresist <br> Defects | 0.7 eV | Mask FAB comparator, print checks, defect density monitor in FAB, voltage stress test and HTOL. | Clean room control, clean mask, pellicles, Statistical Process Control of photoresistetch processes. |
| Contamination | 1.0 eV | C-V stress at oxide/interconnect, wafer FAB device stress test and HTOL. | Statistical Process Control of C-V data, oxide/interconnect cleans, high integrity glassivation and clean assembly processes. |
| Charge Injection | 1.3 eV | HTOL \& oxide characterization. | Design ground rules, wafer level Statistical Process Control and critical dimensions for oxides. |

# ELECTROSTATIC DISCHARGE CONTROL A GUIDE TO HANDLING INTEGRATED CIRCUITS 

This paper discusses methods and materials recommended for protection of ICs against ESD damage or degradation during manufacturing operations vulnerable to ESD exposure. Areas of concern include dice prep and handing, dice and package inspection, packing, shipping, receiving, testing, assembly and all operations where ICs are involved.
All integrated circuits are sensitive to electrostatic discharge (ESD) to some degree. Since the introduction of integrated circuits with MOS structures and high quality junctions, safe and effective means of handling these devices have been of primary importance.
If static discharge occurs at a sufficient magnitude, 2 kV or greater, some damage or degradation will usually occur. It has been found that handling equipment and personnel can generate static potentials in excess of 10kV in a low humidity environment; thus it becomes necessary for additional measures to be implemented to eliminate or reduce static charge. Avoiding any damage or degradation by ESD when handling devices during the manufacturing flow is therefore essential.

## ESD Protection and Prevention Measures

One method employed to protect gate oxide structures is to incorporate input protection diodes directly on the monolithic chip. However, there is no completely foolproof system of chip input protection in existence in the industry.
In areas where ICs are being handled, certain equipment should be utilized to reduce the damaging effects of ESD. Typically, equipment such as grounded work stations, conductive wrist straps, conductive floor mats, ionized air blowers and conductive packaging materials are included in the IC handling environment. Any time an individual intends to handle an IC, in any way, they must insure they have been grounded to eliminate circuit damage.
Grounding personnel can, practically, be performed by two methods. First, grounded wrist straps which are usually made of a conductive material, such as Velostat or metal. A resistor value of 1 megohm ( $1 / 2$ watt) in series with the strap to ground completes a discharge path for ESD when the operator wears the strap in contact with the skin. Another method is to insure direct physical contact with a grounded, conductive work surface.

This consists of a conductive surface like Velostat, covering the work area. The surface is connected to a 1 megohm ( $1 / 2$ watt) resistor in series with ground.

In addition to personnel grounding, areas where work is being performed with ICs, should be equipped with an ionized air blower. lonized air blowers force positive and negative ions simultaneously over the work area so that any nonconductors that are near the work surface would have their static charge neutralized before it would cause device damage or degradation.
Relative humidity in the work area should be maintained as high as practical. When the work environment is less than $40 \%$ RH, a static build-up condition can exist on nonconductors allowing stored charges to remain near the ICs causing possible static electricity discharge to ICs.
Integrated circuits that are being shipped or transported require special handling and packaging materials to eliminate ESD damage. Dice or packaged devices should be in conductive carriers during all phases of transport and handling. Leads of packaged devices can be shorted by tubular metalic carriers, conductive foam or foil.

## Do's and Don'ts for Integrated Circuit Handling

## Do's

Do keep paper, nonconductive plastic, plastic foams and films or cardboard off the static controlled conductive bench top. Placing devices, loaded sticks or loaded burn-in boards on top of any of these materials effectively insulates them from ground and defeats the purpose of the static controlled conductive surface.
Do keep hand creams and food away from static controlled conductive work surfaces. If spilled on the bench top, these materials will contaminate and increase the resistivity of the work area.

Do be especially careful when using soldering guns around conductive work surfaces. Solder spills and heat from the gun may melt and damage the conductive mat.
Do check the grounded wrist strap connections daily. Make certain they are snugly fitted before starting work with the product.
Do put on grounded wrist strap before touching any devices. This drains off any static build-up from the operator.
Do know the ESD caution symbols.
Do remove devices or loaded sticks from shielding bags only when grounded via wrist strap at grounded work station. This also applies when loading or removing devices from the antistatic sticks or the loading on or removing from the burn-in boards.

Do wear grounded wrist straps in direct contact with the bare skin never over clothing.

Do use the same ESD control with empty burn-in boards as with loaded boards if boards contain permanently mounted ICs as part of driver circuits.
Do insure electrical test equipment and solder irons at an ESD control station are grounded and only uninsulated metal hand tools be used. Ordinary plastic solder suckers and other plastic assembly aids shall not be used.
Do use ionizing air blowers in static controlled areas when the use of plastic (nonconductive) materials cannot be avoided.

## Don'ts

Don't allow anyone not grounded to touch devices, loaded sticks or loaded burn-in boards. To be grounded they must be standing on a conductive floor mat with conductive heel straps attached to footwear or must wear a grounded wrist strap.

Don't touch the devices by the pins or leads unless grounded since most ESD damage is done at these points.
Don't handle devices or loaded sticks during transport from work station to work station unless protected by shielding bags. These items must never be directly handled by anyone not grounded.
Don't use freon or chlorinated cleaners at a grounded work area.

Don't wax grounded static controlled conductive floor and bench top mats. This would allow build-up of an insulating layer and thus defeating the purpose of a conductive work surface.

Don't touch devices or loaded sticks or loaded burn-in boards with clothing or textiles even though grounded wrist strap is worn. This does not apply if conductive coats are worn.

Don't allow personnel to be attached to hard ground. There must always be 1 megohm series resistance ( $1 / 2$ watt between the person and the ground).

Don't touch edge connectors of loaded burn-in boards or empty burn-in boards containing permanently mounted
driver circuits when not grounded. This also applies to burnin programming cards containing ICs.

Don't unload stick on a metal bench top allowing rapid discharge of charged devices.

Don't touch leads. Handle devices by their package even though grounded.

Don't allow plastic "snow or peanut" polystyrene foam or other high dielectric materials to come in contact with devices or loaded sticks or loaded burn-in boards.

Don't allow rubber/plastic floor mats in front of static controlled work benches.

Don't solvent-clean devices when loaded in antistatic sticks since this will remove antistatic inner coating from sticks.

Don't use antistatic sticks for more than one throughput process. Used sticks should not be reused unless recoated.

## Recommended Maintenance Procedures

## Daily:

Perform visual inspection of ground wires and terminals on floor mats, bench tops, and grounding receptacles to ensure that proper electrical connections via 1 megohm resistor (1/2 watt) exist.
Clean bench top mats with a soft cloth or paper towel dampened with a mild solution of detergent and water.

## Weekly:

Damp mop conductive floor mats to remove any accumulated dirt layer which causes high resistivity.

## Annually:

Replace nuclear elements for ionized air blowers.
Review ESD protection procedures and equipment for updating and adequacy.

## Static Controlled Work Station

The figure below shows an example of a work bench properly equipped to control electro-static discharge. Note that the wrist strap is connected to a 1 megohm resistor. This resistor can be omitted in the setup if the wrist strap has a 1 megohm assembled on the cable attached.


## PACKAGING INFORMATION

PAGEDSP PACKAGE SELECTION GUIDE ..... 11-3
PACKAGE OUTLINES ..... 11-4
METRIC PLASTIC QUAD FLATPACK (MQFP) PACKAGES ..... 11-4
PLASTIC LEADED CHIP CARRIER (PLCC) PACKAGES ..... 11-6
SMALL OUTLINE PLASTIC (SOIC) PACKAGES ..... 11-7
DUAL-IN-LINE PLASTIC (PDIP) PACKAGES ..... 11-8
CERAMIC PIN GRID ARRAY (CPGA) PACKAGES ..... 11-9
TAPE AUTOMATED BONDING (TAB) PACKAGES ..... 11-14
TAPE AUTOMATED BONDING (TAB) SUGGESTED LEAD FORM DIMENSIONS ..... 11-16


## DSP Package Selection Guide

## Using the Selection Guide:

The first character of each entry indicates the package type, while the number preceding the decimal point details the package lead count. Except for CPGA and TAB packages, the decimal point and succeeding numbers relate to the package body dimensions (e.g. $.14 \times 20=14 \mathrm{~mm} \times 20 \mathrm{~mm} ; .95=950 \mathrm{mil} \mathrm{sq} . ; \quad .3=300$ mils. The entire entry indicates the table containing the appropriate package dimensions (e.g. 24 lead PDIP dimension are detailed in Table E24.3). The index on page 11-1 lists page numbers for MQFP, PLCC, SOIC, PDIP, CPGA and TAB tables.

| PART NUMBER | MQFP | PLCC | SOIC | PDIP | CPGA | TAB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HMA510 |  | N68.95 |  |  | G68.A |  |
| HMA510/883 |  |  |  |  | G68.A |  |
| HMU16 |  | N68.95 |  |  | G68.A |  |
| HMU16/883 |  |  |  |  | G68.A |  |
| HMU17 |  | N68.95 |  |  | G68.A |  |
| HMU17/883 |  |  |  |  | G68.A |  |
| HSP43124 |  |  | M28.3 | E28.6 |  |  |
| HSP43168 | Q100.14×20 | N84.1.15 |  |  | G84.A |  |
| HSP43168/883 |  |  |  |  | G84.A |  |
| HSP43216 |  | N84.1.15 |  |  | G85.A |  |
| HSP43220 | Q100.14×20 | N84.1.15 |  |  | G84.A | S84.A |
| HSP43220/883 |  |  |  |  | G84.A |  |
| HSP43481 |  | N68.95 |  |  | G68.A |  |
| HSP43481/883 |  |  |  |  | G68.A |  |
| HSP43881 |  | N84.1.15 |  |  | G85.A |  |
| HSP43881/883 |  | - |  |  | G85.A |  |
| HSP43891 | Q100.14×20 | N84.1.15 |  |  | G85.A |  |
| HSP43891/883 |  |  |  |  | G85.A |  |
| HSP45102 |  |  | M28.3 | E28.6 |  |  |
| HSP45106 |  | N84.1.15 |  |  | G85.A |  |
| HSP45106/883 |  | N84.1.15 |  |  | G85.A |  |
| HSP45116 | Q160.28×28 |  |  |  | G145.A | S156.A |
| HSP45116A | Q160.28×28 |  |  |  |  |  |
| HSP45116/883 |  |  |  |  | G145.A |  |
| HSP45240 |  | N68.95 |  |  | G68.A |  |
| HSP45240/883 |  |  |  |  | G68.A |  |
| HSP45256 |  | N84.1.15 |  |  | G85.A |  |
| HSP45256/883 |  |  |  |  | G85.A |  |
| HSP48212 | Q64.14×14 | N68.95 |  |  |  |  |
| HSP48410 |  | N84.1.15 |  |  | G84.A |  |
| HSP48410/883 |  | N84.1.15 |  |  | G84.A |  |
| HSP48901 |  | N68.95 |  |  | G68.A |  |
| HSP48908 | Q100.14×20 | N84.1.15 |  |  | G84.A |  |
| HSP48908/883 |  |  |  |  | G84.A |  |
| HSP50016 |  | N44.65 |  |  | G48.A |  |
| HSP9501 |  | N44.65 |  |  |  |  |
| HSP9520 |  |  | M24.3 | E24.3 |  |  |
| HSP9521 |  |  | M24.3 | E24.3 |  |  |

## Package Outlines

## Metric Plastic Quad Flatpack (MQFP) Packages



Q64.14x14 (JEDEC MO-108BD-2 ISSUE A)
64 LEAD METRIC PLASTIC QUAD FLATPACK PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.130 | - | 3.30 | - |
| A1 | 0.004 | 0.010 | 0.10 | 0.25 | - |
| A2 | 0.100 | 0.120 | 2.55 | 3.05 | - |
| B | 0.012 | 0.018 | 0.30 | 0.45 | 6 |
| B1 | 0.012 | 0.016 | 0.30 | 0.40 | $\bullet$ |
| D | 0.667 | 0.687 | 16.95 | 17.45 | 3 |
| D1 | 0.547 | 0.555 | 13.90 | 14.10 | 4,5 |
| E | 0.667 | 0.687 | 16.95 | 17.45 | 3 |
| E1 | 0.547 | 0.555 | 13.90 | 14.10 | 4,5 |
| L | 0.026 | 0.037 | 0.65 | 0.95 | - |
| N | 64 |  | 64 |  | 7 |
| e | 0.032 BSC |  | 0.80 BSC |  | - |

Rev. 0 1/94
NOTES:

1. Controlling dimension: MILLIMETER. Converted inch dimensions are not necessarily exact.
2. All dimensions and tolerances per ANSI Y14.5M-1982.
3. Dimensions D and E to be determined at seating plane
4. Dimensions D1 and E1 to be determined at datum plane $-\mathrm{H}-$
5. Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm ( 0.010 inch) per side.
6. Dimension B does not include dambar protrusion. Allowable dambar protrusion shall be $0.08 \mathrm{~mm}(0.003 \mathrm{inch}$ ) total.
7. " N " is the number of terminal positions.

Metric Plastic Quad Flatpack (MQFP) Packages (Continued)


Q100.14×20 (JEDEC MO-108CC-1 ISSUE A) 100 LEAD METRIC PLASTIC QUAD FLATPACK PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MAX | MIN | MAX | NOTES |  |
| A | $\cdot$ | 0.134 | - | 3.40 | - |
| A1 | 0.010 | - | 0.25 | - | - |
| A2 | 0.100 | 0.120 | 2.55 | 3.05 | - |
| B | 0.009 | 0.015 | 0.22 | 0.38 | 6 |
| B1 | 0.009 | 0.013 | 0.22 | 0.33 | - |
| D | 0.904 | 0.923 | 22.95 | 23.45 | 3 |
| D1 | 0.783 | 0.791 | 19.90 | 20.10 | 4,5 |
| E | 0.667 | 0.687 | 16.95 | 17.45 | 3 |
| E1 | 0.547 | 0.555 | 13.90 | 14.10 | 4,5 |
| L | 0.026 | 0.037 | 0.65 | 0.95 | - |
| N | 100 |  | 100 |  | 7 |
| P | 0.026 BSC |  | 0.65 BSC |  | - |
| ND | 30 |  | 30 |  | - |
| NE | 20 |  | 20 |  | - |

Rev. 0 1/94

Q160.28x28 (JEDEC MO-108DD-1 ISSUE A) 160 LEAD METRIC PLASTIC QUAD FLATPACK PACKAGE

|  | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | MIN | MAX | MIN | MAX |  |
| A | - | 0.160 | - | 4.07 | - |
| A1 | 0.010 | - | 0.25 | - | - |
| A2 | 0.125 | 0.144 | 3.17 | 3.67 | - |
| B | 0.009 | 0.015 | 0.22 | 0.38 | 6 |
| B1 | 0.009 | 0.013 | 0.22 | 0.33 | - |
| D | 1.219 | 1.238 | 30.95 | 31.45 | 3 |
| D1 | 1.098 | 1.106 | 27.90 | 28.10 | 4,5 |
| E | 1.219 | 1.238 | 30.95 | 31.45 | 3 |
| E1 | 1.098 | 1.106 | 27.90 | 28.10 | 4,5 |
| L | 0.026 | 0.037 | 0.65 | 0.95 | - |
| N | 160 |  | 160 |  | 7 |
| B | $0.026 ~ B S C$ |  | 0.65 BSC |  |  |

Rev. 0 1/94
NOTES:

1. Controlling dimension: MILLIMETER. Converted inch dimensions are not necessarily exact.
2. All dimensions and tolerances per ANSI Y14.5M-1982.
3. Dimensions $D$ and $E$ to be determined at seating plane $-\mathrm{C}-$.
4. Dimensions D1 and E1 to be determined at datum plane $-\mathrm{H}^{-}$.
5. Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm ( 0.010 inch) per side.
6. Dimension B does not include dambar protrusion. Allowable dambar protrusion shall be 0.08 mm ( 0.003 inch) total.
7. N " is the number of terminal positions.

## Plastic Leaded Chip Carrier (PLCC) Packages



NOTES:

1. Controlling dimension: INCH. Converted millimeter dimensions are not necessarily exact.
2. Dimensions and tolerancing per ANSI Y14.5M-1982.
3. Dimensions D1 and E1 do not include mold protrusions. Allowable mold protrusion is 0.010 inch ( 0.25 mm ) per side.
4. To be measured at seating plane -C - contact point.
5. Centerline to be determined where center leads exit plastic body.
6. " $N$ " is the number of terminal positions.

N44.65 (JEDEC MS-018 ISSUE A) 44 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |  |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |  |  |  |
| A1 | 0.090 | 0.120 | 2.29 | 3.04 | - |  |  |  |
| D | 0.685 | 0.695 | 17.40 | 17.65 | - |  |  |  |
| D1 | 0.650 | 0.656 | 16.51 | 16.66 | 3 |  |  |  |
| D2 | 0.291 | 0.319 | 7.40 | 8.10 | 4,5 |  |  |  |
| E | 0.685 | 0.695 | 17.40 | 17.65 | - |  |  |  |
| E1 | 0.650 | 0.656 | 16.51 | 16.66 | 3 |  |  |  |
| E2 | 0.291 | 0.319 | 7.40 | 8.10 | 4,5 |  |  |  |
| N | 44 |  |  |  | 44 |  |  | 6 |

Rev. 0 12/93

N68.95 (JEDEC MS-018 ISSUE A) 68 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE

|  | INCHES |  | MILLIMETERS |  | NOTES |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | MIN | MAX | MIN | MAX |  |  |  |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |  |  |  |
| A1 | 0.090 | 0.120 | 2.29 | 3.04 | - |  |  |  |
| D | 0.985 | 0.995 | 25.02 | 25.27 | - |  |  |  |
| D1 | 0.950 | 0.958 | 24.13 | 24.33 | 3 |  |  |  |
| D2 | 0.441 | 0.469 | 11.21 | 11.91 | 4,5 |  |  |  |
| E | 0.985 | 0.995 | 25.02 | 25.27 | - |  |  |  |
| E1 | 0.950 | 0.958 | 24.13 | 24.33 | 3 |  |  |  |
| E2 | 0.441 | 0.469 | 11.21 | 11.91 | 4,5 |  |  |  |
| N | 68 |  |  | 68 |  |  |  | 6 |

Rev. 0 12/93
N84.1.15 (JEDEC MS-018 ISSUE A) 84 LEAD PLASTIC LEADED CHIP CARRIER PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MAX | MIN | MAX | NOTES |  |
| A | 0.165 | 0.180 | 4.20 | 4.57 | - |
| A1 | 0.090 | 0.120 | 2.29 | 3.04 | - |
| D | 1.185 | 1.195 | 30.10 | 30.35 | - |
| D1 | 1.150 | 1.158 | 29.21 | 29.41 | 3 |
| D2 | 0.541 | 0.569 | 13.75 | 14.45 | 4,5 |
| E | 1.185 | 1.195 | 30.10 | 30.35 | - |
| E1 | 1.150 | 1.158 | 29.21 | 29.41 | 3 |
| E2 | 0.541 | 0.569 | 13.75 | 14.45 | 4,5 |
| N | 84 |  |  | 84 |  |

Rev. 0 12/93

## Small Outline Plastic (SOIC) Packages



M24.3 (JEDEC MS-013-AD ISSUE C)
24 LEAD WIDE BODY SMALL OUTLINE PLASTIC PACKAGE

|  | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | MIN | MAX | MIN | MAX | NOTES |
| A | 0.0926 | 0.1043 | 2.35 | 2.65 | - |
| A1 | 0.0040 | 0.0118 | 0.10 | 0.30 | - |
| B | 0.013 | 0.020 | 0.33 | 0.51 | 9 |
| C | 0.0091 | 0.0125 | 0.23 | 0.32 | - |
| D | 0.5985 | 0.6141 | 15.20 | 15.60 | 3 |
| E | 0.2914 | 0.2992 | 7.40 | 7.60 | 4 |
| e | 0.05 BSC |  | 1.27 BSC |  | - |
| H | 0.394 | 0.419 | 10.00 | 10.65 | - |
| h | 0.010 | 0.029 | 0.25 | 0.75 | 5 |
| L | 0.016 | 0.050 | 0.40 | 1.27 | 6 |
| N | 24 |  | 24 |  | 7 |
| $\alpha$ | 0 | $0^{\circ}$ | $8^{\circ}$ | $0^{\circ}$ | $8^{\circ}$ |

Rev. 0 12/93
M28.3 (JEDEC MS-013-AE ISSUE C)
28 LEAD WIDE BODY SMALL OUTLINE PLASTIC PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0.0926 | 0.1043 | 2.35 | 2.65 |  |  |
| A1 | 0.0040 | 0.0118 | 0.10 | 0.30 | - |  |
| B | 0.013 | 0.0200 | 0.33 | 0.51 | 9 |  |
| C | 0.0091 | 0.0125 | 0.23 | 0.32 | - |  |
| D | 0.6969 | 0.7125 | 17.70 | 18.10 | 3 |  |
| E | 0.2914 | 0.2992 | 7.40 | 7.60 | 4 |  |
| $\theta$ | 0.05 BSC |  | 1.27 BSC |  | - |  |
| H | 0.394 | 0.419 | 10.00 | 10.65 | - |  |
| h | 0.01 | 0.029 | 0.25 | 0.75 | 5 |  |
| L | 0.016 | 0.050 | 0.40 | 1.27 | 6 |  |
| N | 28 |  | 28 |  | 7 |  |
| $\alpha$ | $0^{\circ}$ |  | 88 | $0^{\circ}$ | $8^{\circ}$ | - |

Rev. 0 12/93

## Dual-In-Line Plastic (PDIP) Packages



E24.3 (JEDEC MS-001-AF ISSUE D) 24 LEAD NARROW BODY DUAL-IN-LINE PLASTIC PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.210 | - | 5.33 | 4 |
| A1 | 0.015 | - | 0.39 | - | 4 |
| A2 | 0.115 | 0.195 | 2.93 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| B1 | 0.045 | 0.070 | 1.15 | 1.77 | 8 |
| C | 0.008 | 0.014 | 0.204 | 0.355 | - |
| D | 1.230 | 1.280 | 31.24 | 32.51 | 5 |
| D1 | 0.005 | - | 0.13 | - | 5 |
| E | 0.300 | 0.325 | 7.62 | 8.25 | 6 |
| E1 | 0.240 | 0.280 | 6.10 | 7.11 | 5 |
| e | 0.1 | BSC |  | BSC | - |
| $\theta_{A}$ |  | SC |  | BSC | 6 |
| $\theta_{B}$ | - | 0.430 | - | 10.92 | 7 |
| L | 0.115 | 0.150 | 2.93 | 3.81 | 4 |
| N | 24 |  | 24 |  | 9 |

Rev. 0 12/93

E28.6 (JEDEC MS-011-AB ISSUE B) 28 LEAD DUAL-IN-LINE PLASTIC PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.250 | - | 6.35 | 4 |
| A1 | 0.015 | - | 0.39 | - | 4 |
| A2 | 0.125 | 0.195 | 3.18 | 4.95 | - |
| B | 0.014 | 0.022 | 0.356 | 0.558 | - |
| B1 | 0.030 | 0.070 | 0.77 | 1.77 | 8 |
| C | 0.008 | 0.015 | 0.204 | 0.381 | - |
| D | 1.380 | 1.565 | 35.1 | 39.7 | 5 |
| D1 | 0.005 | - | 0.13 | - | 5 |
| E | 0.600 | 0.625 | 15.24 | 15.87 | 6 |
| E1 | 0.485 | 0.580 | 12.32 | 14.73 | 5 |
| e | 0.10 | SC |  | BSC | - |
| $\theta_{A}$ |  | SC |  | BSC | 6 |
| $\theta_{B}$ | - | 0.700 | - | 17.78 | 7 |
| L | 0.115 | 0.200 | 2.93 | 5.08 | 4 |
| N | 28 |  | 28 |  | 9 |

Rev. 0 12/93


## Ceramic Pin Grid Array (CPGA) Packages (Continued)



G68.A MIL-STD-1835 CMGA3-PN (P-AC)
68 LEAD CERAMIC PIN GRID ARRAY PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.215 | 0.345 | 5.46 | 8.76 | - |
| A1 | 0.070 | 0.145 | 1.78 | 3.68 | 3 |
| b | 0.016 | 0.0215 | 0.41 | 0.55 | 8 |
| b1 | 0.016 | 0.020 | 0.41 | 0.51 | - |
| b2 | 0.042 | 0.058 | 1.07 | 1.47 | 4 |
| C | $\bullet$ | 0.080 | - | 2.03 | - |
| D | 1.140 | 1.180 | 28.96 | 29.97 | - |
| D1 | 1.000 BSC |  | 25.4 BSC |  | - |
| E | 1.140 | 1.180 | 28.96 | 29.97 | - |
| E1 | 1.000 BSC |  | 25.4 BSC |  | - |
| e | 0.100 BSC |  | 2.54 BSC |  | 6 |
| k | 0.008 REF |  | 0.20 REF |  | - |
| L | 0.120 | 0.140 | 3.05 | 3.56 | - |
| Q | 0.040 | 0.060 | 1.02 | 1.52 | 5 |
| S | 0.000 BSC |  | 0.00 BSC |  | 10 |
| S1 | 0.003 | - | 0.08 | - | - |
| M | 11 |  | 11 |  | 1 |
| N | - | 121 | - | 121 | 2 |

NOTES:

1. "M" represents the maximum pin matrix size.
2. " N " represents the maximum allowable number of pins. Number of pins and location of pins within the matrix is shown on the pinout listing in this data sheet.
3. Dimension "A1" includes the package body and Lid for both cav-ity-up and cavity-down configurations. This package is cavity up. Dimension does not include heatsinks or other attached features.
4. Standoffs are intrinsic and shall be located on the pin matrix diagonals. The seating plane is defined by the standofis at dimensions Q.
5. Dimension "Q" applies to cavity-up configurations only.
6. All pins shall be on the 0.100 inch grid.
7. Datum C is the plane of pin to package interface for both cavity up and down configurations.
8. Pin diameter includes solder dip or custom finishes. Pin tips shall have a radius or chamfer.
9. Corner shape (chamfer, notch, radius, etc.) may vary from that shown on the drawing. The index corner shall be clearly unique.
10. Dimension " S " is measured with respect to datums A and B .
11. Dimensioning and tolerancing per ANSI Y14.5M-1982.
12. Controlling Dimensions: Inch.
13. Lead Finish: Type C.
14. Materials: Compliant to MIL-I-38535

Ceramic Pin Grid Array (CPGA) Packages (Continued)


G84.A MIL-STD-1835 CMGA3-PN (P-AC) 84 LEAD CERAMIC PIN GRID ARRAY PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.215 | 0.345 | 5.46 | 8.76 | - |
| A1 | 0.070 | 0.145 | 1.78 | 3.68 | 3 |
| b | 0.016 | 0.0215 | 0.41 | 0.55 | 8 |
| b1 | 0.016 | 0.020 | 0.41 | 0.51 | - |
| b2 | 0.042 | 0.058 | 1.07 | 1.47 | 4 |
| C | - | 0.080 | - | 2.03 | - |
| D | 1.140 | 1.180 | 28.96 | 29.97 | - |
| D1 | 1.000 BSC |  | 25.4 BSC |  | - |
| E | 1.140 | 1.180 | 28.96 | 29.97 | - |
| E1 | 1.000 BSC |  | 25.4 BSC |  | - |
| e | 0.100 BSC |  | 2.54 BSC |  | 6 |
| k | 0.008 REF |  | 0.20 REF |  | - |
| L | 0.120 | 0.140 | 3.05 | 3.56 | - |
| Q | 0.040 | 0.060 | 1.02 | 1.52 | 5 |
| S | 0.000 BSC |  | 0.00 BSC |  | 10 |
| S1 | 0.003 | - | 0.08 | - | - |
| M | 11 |  | 11 |  | 1 |
| N | - | 121 | - | 121 | 2 |

NOTES:

1. " $M$ " represents the maximum pin matrix size.
2. " N " represents the maximum allowable number of pins. Number of pins and location of pins within the matrix is shown on the pinout listing in this data sheet.
3. Dimension "A1" includes the package body and Lid for both cav-ity-up and cavity-down configurations. This package is cavity up. Dimension does not include heatsinks or other attached features.
4. Standoffs are intrinsic and shall be located on the pin matrix diagonals. The seating plane is defined by the standoffs at dimensions $Q$.
5. Dimension "Q" applies to cavity-up configurations only.
6. All pins shall be on the 0.100 inch grid.
7. Datum $\mathbf{C}$ is the plane of pin to package interface for both cavity up and down configurations.
8. Pin diameter includes solder dip or custom finishes. Pin tips shall have a radius or chamfer.
9. Corner shape (chamfer, notch, radius, etc.) may vary from that shown on the drawing. The index corner shall be clearly unique.
10. Dimension " S " is measured with respect to datums $\mathbf{A}$ and B .
11. Dimensioning and tolerancing per ANSI $\mathrm{Y} 14.5 \mathrm{M}-1982$.
12. Controlling Dimensions: Inch.
13. Lead Finish: Type C.
14. Materials: Compliant to MIL-I-38535.

Package Outlines

## Ceramic Pin Grid Array (CPGA) Packages (Continued)



G85.A MIL-STD-1835 CMGA3-PN (P-AC) 85 LEAD CERAMIC PIN GRID ARRAY PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.215 | 0.345 | 5.46 | 8.76 | - |
| A1 | 0.070 | 0.145 | 1.78 | 3.68 | 3 |
| b | 0.016 | 0.215 | 0.41 | 0.55 | 8 |
| b1 | 0.016 | 0.020 | 0.41 | 0.51 | - |
| b2 | 0.042 | 0.058 | 1.07 | 1.47 | 4 |
| C | - | 0.080 | - | 2.03 | - |
| D | 1.140 | 1.180 | 28.96 | 29.97 | - |
| D1 | 1.000 BSC |  | 25.4 BSC |  | - |
| E | 1.140 | 1.180 | 28.96 | 29.97 | - |
| E1 | 1.000 BSC |  | 25.4 BSC |  | - |
| e | 0.100 BSC |  | 2.54 BSC |  | 6 |
| k | 0.008 REF |  | 0.20 REF |  | - |
| $L$ | 0.120 | 0.140 | 3.05 | 3.56 | - |
| Q | 0.040 | 0.060 | 1.02 | 1.52 | 5 |
| S | 0.000 BSC |  | 0.00 BSC |  | 10 |
| S1 | 0.003 | - | 0.08 | - | - |
| M | 11 |  | 11 |  | 1 |
| N | - | 121 | - | 121 | 2 |

NOTES:

1. "M" represents the maximum pin matrix size.
2. " N " represents the maximum allowable number of pins. Number of pins and location of pins within the matrix is shown on the pinout listing in this data sheet.
3. Dimension "A1" includes the package body and Lid for both cav-ity-up and cavity-down configurations. This package is cavity up. Dimension does not include heatsinks or other attached features.
4. Standoffs are intrinsic and shall be located on the pin matrix diagonals. The seating plane is defined by the standoffs at dimensions Q.
5. Dimension " $Q$ " applies to cavity-up configurations only.
6. All pins shall be on the 0.100 inch grid.
7. Datum C is the plane of pin to package interface for both cavity up and down configurations.
8. Pin diameter includes solder dip or custom finishes. Pin tips shall have a radius or chamfer.
9. Corner shape (chamfer, notch, radius, etc.) may vary from that shown on the drawing. The index corner shall be clearly unique.
10. Dimension " $S$ " is measured with respect to datums $A$ and $B$.
11. Dimensioning and tolerancing per ANSI Y14.5M-1982.
12. Controlling Dimensions: Inch.
13. Lead Finish: Type C.
14. Materials: Compliant to MIL-I-38535.

## Ceramic Pin Grid Array (CPGA) Packages (Continued)



G145.A MLL-StD-1835 CMGA7-PN (P-AG) 145 LEAD CERAMIC PIN GRID ARRAY PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 0.215 | 0.345 | 5.46 | 8.76 | - |
| A1 | 0.070 | 0.145 | 1.78 | 3.68 | 3 |
| b | 0.016 | 0.0215 | 0.41 | 0.55 | 8 |
| b1 | 0.016 | 0.020 | 0.41 | 0.51 | - |
| b2 | 0.042 | 0.058 | 1.07 | 1.47 | 4 |
| C | - | 0.080 | - | 2.03 | - |
| D | 1.540 | 1.590 | 39.12 | 40.38 | - |
| D1 | 1.400 BSC |  | 35.56 BSC |  | - |
| E | 1.540 | 1.590 | 39.12 | 40.38 | - |
| E1 | 1.400 BSC |  | 35.56 BSC |  | - |
| e | 0.100 BSC |  | 2.54 BSC |  | 6 |
| k | 0.008 REF |  | 0.20 REF |  | - |
| L | 0.120 | 0.140 | 3.05 | 3.56 | - |
| Q | 0.040 | 0.060 | 1.02 | 1.52 | 5 |
| S | 0.000 BSC |  | 0.00 BSC |  | 10 |
| S1 | 0.003 | - | 0.08 | - | - |
| M | 15 |  | 15 |  | 1 |
| N | - | 225 | - | 225 | 2 |

NOTES:

1. "M" represents the maximum pin matrix size.
2. " $N$ " represents the maximum allowable number of pins. Number of pins and location of pins within the matrix is shown on the pinout listing in this data sheet.
3. Dimension "A1" includes the package body and Lid for both cav-ity-up and cavity-down configurations. This package is cavity up. Dimension does not include heatsinks or other attached features.
4. Standoffs are intrinsic and shall be located on the pin matrix diagonals. The seating plane is defined by the standoffs at dimensions Q.
5. Dimension "Q" applies to cavity-up configurations only.
6. All pins shall be on the 0.100 inch grid.
7. Datum C is the plane of pin to package interface for both cavity up and down configurations.
8. Pin diameter includes solder dip or custom finishes. Pin tips shall have a radius or chamfer.
9. Corner shape (chamfer, notch, radius, etc.) may vary from that shown on the drawing. The index corner shall be clearly unique.
10. Dimension " $S$ " is measured with respect to datums $A$ and $B$.
11. Dimensioning and tolerancing per ANSI Y14.5M-1982.
12. Controlling Dimensions: Inch.
13. Lead Finish: Type C.
14. Materials: Compliant to MIL-I-38535.

Tape Automated Bonding (TAB) Packages


S84.A
84 LEAD TAPE AUTOMATED BONDING PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.034 | - | 0.86 | - |
| b | 0.002 | 0.004 | 0.05 | 0.10 | 2,7 |
| c | 0.0010 | 0.0018 | 0.025 | 0.046 | 2,7 |
| B1 | 0.019 | 0.021 | 0.47 | 0.53 | 5 |
| B2 | 0.023 | 0.028 | 0.60 | 0.70 | 5 |
| D | 0.559 | 0.569 | 14.20 | 14.45 | - |
| E | 0.562 | 0.572 | 14.27 | 14.53 | - |
| D1 | 0.410 | 0.420 | 10.41 | 10.67 | 3 |
| E1 | 0.409 | 0.419 | 10.39 | 10.64 | 3 |
| D2 | 0.300 | 0.310 | 7.62 | 7.87 | 4 |
| E2 | 0.300 | 0.310 | 7.62 | 7.87 | 4 |
| D3/E3 | 0.500 BSC |  | 12.70 BSC |  | - |
| D4/E4 | 0.531 BSC |  | 13.475 BSC |  | - |
| D5/E5 | 1.061 BSC |  | 26.95 BSC |  | - |
| D6 | 1.372 | 1.382 | 34.85 | 35.10 | - |
| E6 | 1.244 | 1.314 | 31.62 | 33.37 | - |
| D7 | 0.345 | 0.351 | 8.77 | 8.92 | - |
| E7 | 0.344 | 0.350 | 8.74 | 8.89 | - |
| D8 | 0.360 | 0.370 | 9.14 | 9.40 | - |
| E8 | 0.358 | 0.368 | 9.09 | 9.35 | - |
| e | 0.015 BSC |  | 0.38 BSC |  | 2 |
| e1 | 0.016 BSC |  | 0.40 BSC |  | 5 |
| F | 0.054 | 0.057 | 1.39 | 1.45 | - |
| G | 0.055 | 0.057 | 1.40 | 1.45 | - |
| H | 1.253 BSC |  | 31.83 BSC |  | - |
| H1 | 0.187 BSC |  | 4.75 BSC |  | - |
| aaa | 0.003 |  | 0.08 |  | - |

NOTES:

1. All dimensioning and tolerancing per ANSI Y14.5M1982.
2. Controlling dimension is MILLIMETERS except for dimensions $\mathrm{b}, \mathrm{c}$ and e which are in INCHES.
3. Dimensions D1/E1 define the package "body size".
4. Dimensions D2/E2 define the maximum allowable dimension between the outside edges of the outermost leads. This dimension provides necessary clearance from the OLB window corners for excise operations.
5. This dimension applies to all test pads.
6. All lead and test pad arrays shall be arranged in a symmetric configuration with respect to datums D or B-C.
7. Dimensions $\mathbf{b}$ and c apply to base material only.
8. Lead Material: Copper Lead Finish: Gold over nickel underplate
9. Film format and test pads per JEDEC US-001, Ax-2x.
10. TAB packages shipped in slide carriers per JEDEC CS-006 with the leads unformed (flat).

Tape Automated Bonding (TAB) Packages (Continued)


SECTION A-A

S156.A
156 LEAD TAPE AUTOMATED BONDING PACKAGE

| SYMBOL | INCHES |  | MILLIMETERS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | - | 0.034 | - | 0.86 | - |
| b | 0.002 | 0.004 | 0.05 | 0.10 | 2 |
| c | 0.0010 | 0.0018 | 0.025 | 0.046 | 2,7 |
| B1 | 0.019 | 0.021 | 0.47 | 0.53 | 5 |
| B2 | 0.023 | 0.028 | 0.60 | 0.70 | 5 |
| D | 0.559 | 0.569 | 14.20 | 14.45 | - |
| E | 0.562 | 0.572 | 14.27 | 14.53 | - |
| D1 | 0.429 | 0.439 | 10.90 | 11.15 | 3 |
| E1 | 0.431 | 0.441 | 10.95 | 11.20 | 3 |
| D2 | 0.380 | 0.390 | 9.65 | 9.90 | 4 |
| E2 | 0.380 | 0.390 | 9.65 | 9.90 | 4 |
| D3/E3 | 0.500 BSC |  | 12.70 BSC |  | - |
| D4/E4 | 0.531 BSC |  | 13.475 BSC |  | - |
| D5/E5 | 1.061 BSC |  | 26.95 BSC |  | - |
| D6 | 1.372 | 1.382 | 34.85 | 35.10 | - |
| E6 | 1.244 | 1.314 | 31.62 | 33.37 | - |
| D7 | 0.349 | 0.355 | 8.87 | 9.02 | - |
| E7 | 0.346 | 0.352 | 8.79 | 8.94 | - |
| D8 | 0.360 | 0.370 | 9.14 | 9.40 | - |
| E8 | 0.367 | 0.377 | 9.32 | 9.57 | - |
| e | 0.010 BSC |  | 0.254 BSC |  | 2 |
| e1 | 0.016 BSC |  | 0.40 BSC |  | 5 |
| F | 0.054 | 0.057 | 1.39 | 1.45 | - |
| G | 0.055 | 0.057 | 1.40 | 1.45 | - |
| H | 1.253 BSC |  | 31.83 BSC |  | - |
| H1 | 0.187 BSC |  | 4.75 BSC |  | - |
| aaa | 0.002 |  | 0.05 |  | - |

NOTES:

1. All dimensioning and tolerancing per ANSI Y14.5M1982.
2. Controlling dimension is MILLIMETERS except for dimensions $b, c$ and e which are in INCHES.
3. Dimensions D1/E1 define the package "body size".
4. Dimensions D2/E2 define the maximum allowable dimension between the outside edges of the outermost leads. This dimension provides necessary clearance from the OLB window corners for excise operations.
5. This dimension applies to all test pads.
6. All lead and test pad arrays shall be arranged in a symmetric configuration with respect to datums D or B-C.
7. Dimensions $b$ and $c$ apply to base material only.
8. Lead Material: Copper Lead Finish: Gold over nickel underplate
9. Film format and test pads per JEDEC US-001, Ax-2x.
10. TAB packages shipped in slide carriers per JEDEC CS-006 with the leads unformed (flat).

Tape Automated Bonding (TAB) Suggested Lead Form Dimensions


| CONSTANT DIMENSIONS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{b}$ | $\mathbf{G}$ | $\mathbf{H}$ | $\mathbf{J}$ | $\mathbf{K}$ | $\mathbf{L}$ | $\mathbf{M}$ | $\mathbf{c}$ | $\mathbf{R}$ | $\mathbf{S}$ |
| 0.003 | 0.475 | 0.515 | 0.472 | 0.512 | 0.020 | 0.0114 | 0.0014 | 0.0057 | 0.0224 |


| DEVICE DEPENDENT DIMENSIONS |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DEVICE | LEADS | E1 | D1 | E2 | D2 | C | - | $E_{\chi}$ | $\mathrm{E}_{\mathrm{Y}}$ | E7 | D7 | z |
| HSP43220 | 84 | 0.414 | 0.415 | 0.305 | 0.305 | 0.025 | 0.015 | 0.0545 | 0.0550 | 0.348 | 0.349 | 0.019 |
| HSP45116 | 156 | 0.436 | 0.434 | 0.385 | 0.385 | 0.032 | 0.010 | 0.0256 | 0.0245 | 0.350 | 0.353 | 0.019 |

# DSP 

## HOW TO USE HARRIS AnswerFAX

## What is AnswerFAX?

AnswerFAX is Harris' automated fax response system. It gives you on-demand access to a full library of the latest data sheets, application notes, and other information on Harris products.

## What do I need to use AnswerFAX?

Just a fax machine and a touch-tone phone. You can access it 24 hours a day, 7 days a week.

## How does it work?

You call the AnswerFAX number, touch-tone your way through a series of recorded questions, enter the order numbers of the documents you want, and give AnswerFAX a fax number to send them to. You'll have the information you need in minutes. The chart on the next page shows you how.

## How do I find out the order number for the publications I want?

The first time you call AnswerFAX, you should order one or more on-line catalogs of product line information. There are seven catalogs:

- New Products
- Linear/Telecom Products
- Data Acquisition Products

Once they're faxed to you, you can call back and order the publications themselves by number.

## - - - <br> How do I start?

Dial 407-724-3818. That's it.


Please refer to next page for a map to AnswerFAX.

## Your Map to Harris AnswerFAX



| DATA BOOKS AVAILABLE NOW! |  |
| :---: | :---: |
| PUBLICATION NUMBER | DATA BOOK/DESCRIPTION |
| PSG201S | PRODUCT SELECTION GUIDE (1992: 320pp) Key product information on all Harris Semiconductor devices. Sectioned (Analog, Data Acquisition, Digital, Application Specific, Power, Hi-Rel \& Rad-Hard, ASIC) for easy use and includes cross references and alphanumeric part number index. |
| DB500B | LINEAR AND TELECOM ICs (1993: 1,312pp) Product specifications for: op amps, comparators, S/H amps, differential amps, arrays, special analog circuits, telecom ICs, and power processing circuits. |
| DB301B | DATA ACQUISITION (1994: 1,104pp) Product specifications on A/D converters (display, integrating, successive approximation, flash); D/A converters, switches, multiplexers, and other products. |
| DB302A | DIGITAL SIGNAL PROCESSING (1993: 380pp) This new edition includes specifications on one- and two-dimensional filters, signal synthesizers, multipliers, special function devices (such as address sequencers, binary correlators, histogrammer). Includes sections on development tools, application notes and Quality/Reliability. |
| DB304 | INTELLIGENT POWER ICs (1992: 512pp) Product specifications for low- and high-side switches, half bridges, $A C-D C$ converters, full bridges, regulators \& power supplies, protection circuits, and special function ICs. Includes application notes and Quality/Reliability sections. |
| DB450C | TRANSIENT VOLTAGE SUPPRESSION DEVICES (1994: 400pp) Product specifications of Harris varistors and surgectors. Also, general informational chapters such as: "Voltage Transients - An Overview," "Transient Suppression - Devices and Principles," "Suppression - Automotive Transients." |
| DB223.2 | POWER MOSFETs (1992: 1,504pp) Product specifications on MOSFETs ( N - and P-channel, logic level, military and radiation-hardened); IGBTs; Intelligent discretes; power drivers and switches; and ultra-fast rectifiers. Includes industry replacement guide and application notes. |
| DB220.1 | BIPOLAR POWER TRANSISTORS (1992: 592pp) Technical information on over 750 power transistors for use in a wide range of consumer, industrial and military applications. Indexing and packaging included. |
| DB303 | MICROPROCESSOR PRODUCTS (1992: 1,156pp) For commercial and military applications. Product specifications on CMOS microprocessors, peripherals, data communications, and memory ICs. Includes application notes and Quality/Reliability chapters. |
| DB309 | MCT/GBET/DIODES (1994: 528pp) This databook fully describes Harris Semiconductor's line of MOS Controlled Thyristors, Insulated Gate Bipolar Transistors (IGBTs) and Power Diodes/Rectifiers. It includes a complete set of datasheets for product specifications, application notes with design details for specific applications of Harris products, and a description of the Harris Quality and Reliability program. |
| Analog Military | ANALOG MILTTARY (1989: 1,264pp) This databook describes Harris' military line of Linear, Data Acquisition, and Telecommunications circuits. |
| Digital Military | DIGITAL MILITARY (1989: 680pp) Harris CMOS digital ICs -- microprocessors, peripherals, data communications and memory -- are included in this databook. |

NAME:

MAIL STOP:

PHONE: $\qquad$
FAX: $\qquad$ DATA BOOK REQUESTED: $\qquad$

| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 27007 | BR007 | Complete Listing of Harris Sales Offices, Representatives and Authorized Distributors World Wide (7 pages) |
| HARRIS SEMICONDUCTOR APPLICATION NOTES |  |  |
| 9001 | AN001 | Glossary of Data Conversion Terms (6 pages) |
| 9002 | ANOO2 | Principles of Data Acquisition and Conversion (20 pages) |
| 9004 | ANOO4 | The IH5009 Analog Switch Series (9 pages) |
| 9007 | AN007 | Using the 8048/8049 Log/Antilog Amplifier (6 pages) |
| 9009 | ANOO9 | Pick Sample-Holds by Accuracy and Speed and Keep Hold Capacliors in Mind (7 pages) |
| 9012 | AN012 | Switching Signals with Semiconductors (4 pages) |
| 9013 | ANO13 | Everything You Always Wanted to Know About the ICL8038 (4 pages) |
| 9016 | AN016 | Selecting A/D Converters (7 pages) |
| 9017 | AN017 | The Integrating AND Converter ( 5 pages) |
| 9018 | AN018 | Do's and Don'ts of Applying ADD Converters (4 pages) |
| 9020 | AN020 | A Cookbook Approach to High Speed Data Acquisition and Microprocessor Interfacing (23 pages) |
| 9023 | AN023 | Low Cost Digital Panel Meter Designs (5 pages) |
| 9027 | AN027 | Power Supply Design Using the ICL8211 and 8212 (8 pages) |
| 9028 | AN028 | Build an Auto-Ranging DMM with the ICL7103A/8052A AD Converter Pair (6 pages) |
| 9030 | AN030 | ICL7104: A Binary Output ADD Converter for Microprocessors (16 pages) |
| 9032 | AN032 | Understanding the Auto-Zero and Common Mode Performance of the ICL7106/7107/7109 Family (8 pages) |
| 9040 | AN040 | Using the ICL8013 Four Quadrant Analog Multiplier ( 6 pages) |
| 9042 | AN042 | Interpretation of Data Converter Accuracy Specifications (11 pages) |
| 9043 | AN043 | Video Analog-to-Digital Conversion (6 pages) |
| 9046 | AN046 | Building a Battery Operated Auto Ranging DVM with the ICL7106 (5 pages) |
| 9047 | AN047 | Games People Play with Intersil's A/D Converter's (27 pages) |


| Answerfax DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 9048 | AN048 | Know Your Converter Codes (5 pages) |
| 9049 | AN049 | Applying the 7109 ADD Converter (5 pages) |
| 9051 | AN051 | Principles and Applications of the ICL7660 CMOS Voltage Converter (9 pages) |
| 9052 | AN052 | Tips for Using Single Chip 3.5 Digit A/D Converters (9 pages) |
| 9053 | AN053 | The ICL7650 A New Era in Glitch-Free Chopper Stabilized Amplifiers <br> (19 pages) |
| 9054 | AN054 | Display Driver Family Combines Convenience of Use with Microprocessor Interfaceability ( 18 pages) |
| 9059 | AN059 | Digital Panel Meter Experiments for the Hobbyist (7 pages) |
| 9108 | AN108 | 82C52 Programmable UART (12 pages) |
| 9109 | AN109 | 82C59A Priority Interrupt Controller (14 pages) |
| 9111 | AN111 | Harris 80C286 Performance <br> Advantages Over the 80386 ( 12 pages) |
| 9112 | AN112 | 80C286/80386 Hardware Comparison (4 pages) |
| 9113 | AN1 13 | Some Applications of Digital Signal Processing Techniques to Digital Video (5 pages) |
| 9114 | AN114 | Real-Time Two-Dimensional Spatial Filtering with the Harris Digital Filter Family (43 pages) |
| 9115 | AN115 | Digital Filter (DF) Family Overview (6 pages) |
| 9116 | AN116 | Extended DF Configurations (10 pages) |
| 9120 | AN120 | Interfacing the 80C286-16 With the 80287-10 (2 pages) |
| 9121 | AN121 | Harris 80 C 286 Performance Advantages Over the 80386SX ( 14 pages) |
| 9400 | AN400 | Using the HS-3282 ARINC Bus Interface Circuit (6 pages) |
| 9509 | AN509 | A Simple Comparator Using the HA-2620 (1 page) |
| 9514 | AN514 | The HA-2400 PRAM Four Channel Operational Amplifier (7 pages) |
| 9515 | AN515 | Operational Amplifier Stability: Input Capacitance Considerations (2 pages) |
| 9517 | AN517 | Applications of Monolithic Sample and Hold Amplifier (5 pages) |
| 9519 | AN519 | Operational Amplifier Noise Prediction (4 pages) |

# AnswerFAX Technical Support Application Note Listing 

| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 9520 | AN520 | CMOS Analog Miltiplexers and Switches; Applications Considerations <br> (9 pages) |
| 9521 | AN521 | Getting the Most Out of CMOS Devices for Analog Switching Jobs (7 pages) |
| 9522 | AN522 | Digital to Analog Converter Terminology (3 pages) |
| 9524 | AN524 | Digital to Analog Converter High Speed ADC Applications (3 pages) |
| 9525 | AN525 | HA-5190/5195 Fast Settling Operational Amplifier (4 pages) |
| 9526 | AN526 | Video Applications for the HA-5190/ 5195 (5 pages) |
| 9531 | AN531 | Analog Switch Applications in ADD Data Conversion Systems (4 pages) |
| 9532 | AN532 | Common Questions Conceming CMOS Analog Switches (4 pages) |
| 9534 | AN534 | Additional Information on the HI-300 Series Switch (5 pages) |
| 9535 | AN535 | Design Considerations for A Data Acquisition System (DAS) (7 pages) |
| 9538 | AN538 | Monolithic Sample/Hold Combines Speed and Precision (6 pages) |
| 9539 | AN539 | A Monolithic 16-Bit D/A Converter (5 pages) |
| 9540 | AN540 | HA-5170 Precision Low Noise JFET Input Operation Amplifier (4 pages) |
| 9541 | AN541 | Using HA-2539 or HA-2540 Very High Slew Rate, Wideband Operational Amplifier (4 pages) |
| 9543 | AN543 | New High Speed Switch Offers Sub-50ns Switching Times (7 pages) |
| 9544 | AN544 | Micropower Op Amp Family (6 pages) |
| 9546 | AN546 | A Method of Calculating HA-2625 Gain Bandwidth Product vs. Temperature (4 pages) |
| 9548 | AN548 | A Designers Guide for the HA-5033 Video Buffer (12 pages) |
| 9549 | AN549 | The HC-550X Telephone Subscriber Line Interface Circuits (SLIC) (19 pages) |
| 9550 | AN550 | Using the HA-2541(6 pages) |
| 9551 | AN551 | Recommended Test Procedures for Operational Amplifiers ( 6 pages) |
| 9552 | AN552 | Using the HA-2542 (5 pages) |
| 9553 | AN553 | HA-5147/37/27, Ultra Low Noise Amplifiers (8 pages) |
| 9554 | AN554 | Low Noise Family HA-5101/02/04/11/12/14 (7 pages) |


| AnswerfAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 9556 | AN556 | Thermal Safe-Operating-Areas for High Current Op Amps (5 pages) |
| 9557 | AN557 | Recommended Test Procedures for Analog Switches ( 6 pages) |
| 9558 | AN558 | Using the HV-1205 AC to DC Converter (2 pages) |
| 9559 | AN559 | HI-222 Video/HF Switch Optimizes Key Parameters (7 pages) |
| 9571 | AN571 | Using Ring Sync with HC-5502A and HC-5504 SLICs (2 pages) |
| 9573 | AN573 | The HC-5560 Digital Line Transcoder (6 pages) |
| 9574 | AN574 | Understanding PCM Coding (3 pages) |
| 9576 | AN576 | HC-5512 PCM Filter Cleans Up CVSD Codec Signals (2 pages) |
| 9607 | AN607 | Delta Modulation for Voice Transmission (5 pages) |
| 95290 | AN5290 | Integrated Circuit Operational Amplifiers (20 pages) |
| 96048 | AN6048 | Some Applications of A Programmable Power Switch/Amp (12 pages) |
| 96077 | AN6077 | An IC Operational-TransconductanceAmplifier (OTA) With Power Capability (12 pages) |
| 96157 | AN6157 | Applications of the CA3085 Series Monolithic IC Voltage Regulators (11 pages) |
| 96182 | AN6182 | Features and Applications of Integrated Clicult Zero-Voltage Switches (CA3058, CA3059 and CA3079) (31 pages) |
| 96386 | AN6386 | Understanding and Using the CA3130, CA3130A and CA3130B30A/30B BiMOS Operation Amplifiers ( 5 pages) |
| 96459 | AN6459 | Why Use the CMOS Operational Amplifiers and How to Use it (4 pages) |
| 96565 | AN6565 | Design of Clock Generators For Use With COSMAC Microprocessor CDP1802 (3 pages) |
| 96669 | AN6669 | FET-Bipolar Monolithic Op Amps Mate Directly to Sensitive Sources (3 pages) |
| 96915 | AN6915 | Application of CA1524 Series Pulse-Width Modulator ICs (18 pages) |
| 96970 | AN6970 | Understanding and Using the CDP1855 Multiply/Divide Unit (11 pages) |
| 97063 | AN7063 | Understanding the CDP1851 Programmable I/O (7 pages) |
| 97174 | AN7174 | The CA1524E Pulse-Width ModulatorDriver for an Electronic Scale (2 pages) |


| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 97244 | AN7244 | Understanding Power MOSFETs (4 pages) |
| 97254 | AN7254 | Switching Waveforms of the L ${ }^{2}$ FET: A 5 Volt Gate-Drive Power MOSFET (8 pages) |
| 97260 | AN7260 | Power MOSFET Switching Waveforms: A New Insight (7 pages) |
| 97275 | AN7275 | User's Guide to the CDP1879 and CDP1879C1 CMOS Real-Time Clocks (18 pages) |
| 97326 | AN7326 | Applications of the CA3228E Speed Control System (16 pages) |
| 97332 | AN7332 | The Application of Conductivity-Modulated Field-Effect Transistors (5 pages) |
| 97374 | AN7374 | The CDP1871A Keyboard Encoder (9 pages) |
| 98602 | AN8602 | The IGBTs - A New High Conductance MOS-Gated Device (3 pages) |
| 98603 | AN8603 | Improved IGBTs with Fast Switching Speed and High-Current Capability (4 pages) |
| 98610 | AN8610 | Spicing-Up Spice II Software for Power MOSFET Modeling (8 pages) |
| 98614 | AN8614 | The CA1523 Variable Interval Pulse Regulator (VIPUR) For Switch Mode Power Supplies (13 pages) |
| 98707 | AN8707 | The CA3450: A Single-Chip Video Line Driver and High Speed Op Amp (14 pages) |
| 98742 | AN8742 | Application of the CD22402 Video Sync Generator (4 pages) |
| 98743 | AN8743 | Micropower Crystal-Controlled Oscillator Design Using CMOS Inverters (8 pages) |
| 98754 | AN8754 | Method of Measurement of Simultaneous Switching Transient (3 pages) |
| 98756 | AN8756 | A Comparative Description of the UART (16 pages) |
| 98759 | AN8759 | Low Cost Data Acquisition System Features SPI AD Converter (9 pages) |
| 98761 | AN8761 | User's Guide to the CDP68HC68T1 Real-Time Clock (14 pages) |
| 98811 | AN8811 | BimOS-E Process Enhances the CA5470 Quad Op Amp (8 pages) |
| 98818 | AN8818 | Exceptional Radiation Levels from Sili-con-on-Sapphire Processed HighSpeed CMOS Logic (5 pages) |
| 98820 | AN8820 | Recommendations for Soldering Terminal Leads to MOV Varistor Discs (2 pages) |


| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 98823 | AN8823 | CMOS Phase-Locked-Loop Applications Using the CD54/74HC/HCT4046A and CD54/74HC/HCT7046A (23 pages) |
| 98829 | AN8829 | SP600 and SP601 an HVIC MOSFET/ IGBT Driver for Half-Bridge Topologies (6 pages) |
| 98910 | AN8910 | An Introduction to Behavioral Simulatlon Using Harris AC/ACT Logic SmartModels ${ }^{\text {TM }}$ From Logic Automation Inc. (9 pages) |
| 99001 | AN9001 | Measuring Ground and VCC Bounce in Advanced High Speed (AC/ACT/FCT) CMOS Logic ICs (4 pages) |
| 99002 | AN9002 | Transient Voltage Suppression in Automotive Vehicles (8 pages) |
| 99003 | AN9003 | Low-Voltage Metal-Oxide Varistor Protection for Low Voltage ( $\mathbf{5} 5 \mathrm{~V}$ ) ICs (13 pages) |
| 99010 | AN9010 | HIP2500 High Voltage ( $500 \mathrm{~V}_{\mathrm{DC}}$ ) HalfBridge Driver IC (8 pages) |
| 99011 | AN9011 | Synchronous Operation of Harris Rad Hard SOS 64K Asynchronous SRAMs (4 pages) |
| 99101 | AN9101 | High Current Off Line Power Supply (4 pages) |
| 99102 | AN9102 | Noise Aspects of Applying Advanced CMOS Semiconductors (9 pages) |
| 99105 | AN9105 | HVIC/IGBT Half-Bridge Converter Evaluation Circuit (1 page) |
| 99106 | AN9106 | Special ESD Considerations for the HS 65643RH and HS-65647RH Radiation Hardened SOS SRAMs (2 pages) |
| 99108 | AN9108 | Harris Multilayer Surface Mount Surge Suppressors ( 10 pages) |
| 99201 | AN9201 | Protection Circuits for Quad and Octal Low Side Power Drivers (8 pages) |
| 99202 | AN9202 | Using the HFA1100, HFA1 130 Evaluation Fixture (4 pages) |
| 99203 | AN9203 | Using the H15800 Evaluation Board (13 pages) |
| 99204 | AN9204 | Tools for Controlling Voltage Surges and Noise (4 pages) |
| 99205 | AN9205 | Timing Relationships for HSP45240 (2 pages) |
| 99206 | AN9206 | Correlating on Extended Data Lengths (2 pages) |
| 99207 | AN9207 | DSP Temperature Considerations (2 pages) |
| 99208 | AN9208 | High Frequency Power Converters (10 pages) |

## AnswerFAX Technical Support Application Note Listing

| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 99209 | AN9209 | A Spice-2 Subcircuit Representation for Power MOSFETs, Using Empirical Methods (4 pages) |
| 99210 | AN9210 | A New PSpice Subcircuit for the Power MOSFET Featuring Global Temperature Options (12 pages) |
| 99211 | AN9211 | Soldering Recommendations for Surface Mount Metal Oxide Varistors and Multilayer Transient Voltage Suppressors (8 pages) |
| 99212 | AN9212 | HIP5060 Family of Current Mode Control ICs Enhance 1MHz Regulator Performance (7 pages) |
| 99213 | AN9213 | Advantages and Application of Display Integrating A/D Converters (6 pages) |
| 99214 | AN9214 | Using Harris High Speed AND Converters (10 pages) |
| 99215 | AN9215 | Using the $\mathrm{HI}-5700$ Evaluaton Board (7 pages) |
| 99216 | AN9216 | Using the HI5701 Evaluation Board (8 pages) |
| 99217 | AN9217 | High Current Off Line Power Supply <br> (11 pages) |
| 99301 | AN9301 | High Current Logic Level MOSFET Driver (3 pages) |
| 99302 | AN9302 | CA3277 Dual 5V Regulator Circuit Applications (9 pages) |
| 99303 | AN9303 | Upgrading Your Application to the Hi7166 or HI7167 (7 pages) |
| 99304 | AN9304 | ESD and Transient Protection Using the SP720 (10 pages) |
| 99306 | AN9306 | The New 'C' III Series of Metal Oxide Varistors (5 pages) |
| 99307 | AN9307 | The Connector Pin Varistor for Transient Voltage Protection in Connectors ( 7 pages) |
| 99308 | AN9308 | Voltage Transients and their Suppression (5 pages) |
| 99309 | AN9309 | Using the H15800/Hi5801 Evaluation Board (8 pages) |
| 99310 | AN9310 | Surge Suppression Technologies Advantages and Disadvantages (MOVs, SADs, Gas Tubes, Filters and Transformers) (6 pages) |
| 99311 | AN9311 | The ABCs of MOVs (3 pages) |
| 99312 | AN9312 | Suppression of Transients in an Automative Environment (11 pages) |
| 99313 | AN9313 | Circuit Considerations in Imaging Applications (8 pages) |
| 99314 | AN9314 | Harris UHF Pin Drivers (4 pages) |


| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 99315 | AN9315 | RF Amplifier Design Using HFA3046/ 3096/3127/3128 Transistor Arrays (4 pages) |
| 99316 | AN9316 | Power Supply Considerations for the HI-222 High Frequency Video Switch (2 pages) |
| 99317 | AN9317 | Micropower Clock Oscillator and Op Amps Provide System Control for Battery Operated Circuits (2 pages) |
| 99321 | AN9321 | Single Pulse Unclamped Inductive Switching: A Rating System (5 pages) |
| 99322 | AN9322 | A Combined Single Pulse and Repetitive UIS Rating System (4 pages) |
| 99323 | AN9323 | HIP5061 High Efficiency, High Performance, High Power Converter (10 pages) |
| 99324 | AN9324 | HIP4080, 80V Frequency H-Bridge Driver (12 pages) |
| 99327 | AN9327 | HC-5509A1 Ring Trip Component Selection (9 pages) |
| 99328 | AN9328 | Using the Hil166 Evaluation Board (9 pages) |
| 99329 | AN9329 | Using the H11176/HI1171 Evaluation Board (5 pages) |
| 99330 | AN9330 | Using the H11396 Evaluation Board (9 pages) |
| 99331 | AN9331 | Using the HI1175 Evaluation Board (10 pages) |
| 99332 | AN9332 | Using the HI1276 Evaluation Board (10 pages) |
| 99333 | AN9333 | Using the Hl1386 Adapter Board (2 pages) |
| 99334 | AN9334 | Improving Start-Up Time at 32 kHz for the HA7210 Low Power Crystal Oscillator (2 pages) |
| 99335 | AN9335 | HIP5500 High Voltage ( $500 \mathrm{~V}_{\mathrm{DC}}$ ) Power Supply Driver IC (13 pages) |
| 99337 | AN9337 | Reduce CMOS-Multiplexer Troubles Through Proper Device Selection ( 6 pages) |
| 660001 | MM0001 | HFA-0001 Spice Operational Amplifier Macro-Model (4 pages) |
| 660002 | MM0002 | HFA-0002 Spice Operational Amplifier Macro-Model (4 pages) |
| 660005 | MM0005 | HFA-0005 Spice Operational Amplifier Marco-Model (4 pages) |
| 662500 | MM2500 | HA2500/02 Spice Operational Amplifier Macro-Model (5 pages) |
| 662510 | MM2510 | HA-2510/12 Spice Operational Amplifier Macro-Model (4 pages) |

HARRIS
AnswerFAX Technical Support Application Note Listing

| Answerfax DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 662520 | MM2520 | HA-2520/22 Spice Operational Amplifier Macro-Model (4 pages) |
| 662539 | MM2539 | HA-2539 Spice Operational Amplifier Macro-Model (4 pages) |
| 662540 | MM2540 | HA-2540 Spice Operational Amplifier Macro-Model (4 pages) |
| 662541 | MM2541 | HA-2541 Spice Operational Amplifier Macro-Model (5 pages) |
| 662542 | MM2542 | HA-2542 Spice Operational Amplifier Macro-Model (5 pages) |
| 662544 | MM2544 | HA-2544 Spice Operational Amplifier Macro-Model (5 pages) |
| 662548 | MM2548 | HA-2548 Spice Operational Amplifier Macro-Model (5 pages) |
| 662600 | MM2600 | HA-2600/02 Spice Operational Amplifier Macro-Model (5 pages) |
| 662620 | MM2620 | HA-2620/22 Spice Operational Amplifier Macro-Model (5 pages) |
| 662839 | MM2839 | HA-2839 Spice Operational Amplifier Macro-Model (4 pages) |
| 662840 | MM2840 | HA-2840 Spice Operational Amplifier Macro-Model (4 pages) |
| 662841 | MM2841 | HA-2841 Spice Operational Amplifier Macro-Model (4 pages) |
| 662842 | MM2842 | HA-2842 Spice Operational Amplifier Macro-Model (4 pages) |
| 662850 | MM2850 | HA-2850 Spice Operational Amplifier Macro-Model (4 pages) |
| 665002 | MM5002 | HA-5002 Spice Buffer Amplifier Macro-Model (4 pages) |


| AnswerFAX DOCUMENT NUMBER | PART NUMBER | DESCRIPTION |
| :---: | :---: | :---: |
| 665004 | MM5004 | HA-5004 Spice Current Feedback Amplifier Macro-Model (4 pages) |
| 665020 | MM5020 | HA-5020 Spice Current Feedback Operational Amplifier Macro-Model (4 pages) |
| 665033 | MM5033 | HA-5033 Spice Buffer Amplifier Macro-Model (4 pages) |
| 665101 | MM5101 | HA-5101 Spice Operational Amplifier Macro-Model ( 5 pages) |
| 665102 | MM5102 | HA-5102 Spice Operational Amplifier Macro-Model (5 pages) |
| 665104 | MM5104 | HA-5104 Spice Operational Amplifier Macro-Model ( 5 pages) |
| 665112 | MM5112 | HA-5112 Spice Operational Amplifier Macro-Model ( 5 pages) |
| 665114 | MM5114 | HA-5114 Spice Operational Amplifier Macro-Model (5 pages) |
| 665127 | MM5127 | HA-5127 Spice Operational Amplifier Macro-Model (4 pages) |
| 665137 | MM5137 | HA-5137 Spice Operational Amplifier Macro-Model (4 pages) |
| 665147 | MM5147 | HA-5147 Spice Operational Amplifier Macro-Model (4 pages) |
| 665190 | MM5190 | HA-5190 Spice Operational Amplifier Macro-Model (4 pages) |
| 665221 | MM5221 | HA-5221/22 Spice Operational Amplifier Macro-Model (4 pages) |
| 797338 | MM PWRDEV | Harris Power MOSFET and MCT Spice Model Library (16 pages) |

## SALES OFFICES

A complete and current listing of all Harris Sales, Representative and Distributor locations worldwide is available. Please order the "Harris Sales Listing" from the Literature Center (see page iii).

HARRIS HEADQUARTER LOCATIONS BY COUNTRY:

| U.S. HEADQUARTERS | EUROPEAN HEADQUARTERS |
| :--- | :--- |
| Harris Semiconductor | Harris Semiconductor |
| 1301 Woody Burke Road | Mercure Centre |
| Melbourne, Florida 32901 | 100, Rue de la Fusse |
| TEL: (407) 724-3000 | 1130 Brussels, Belgium |
|  | TEL: 3222462111 |
| SOUTH ASIA | NORTH ASIA |
| Harris Semiconductor H.K. Ltd | Harris K.K. |
| 13/F Fourseas Building | Shinjuku NS Bldg. Box 6153 |
| 208-212 Nathan Road | $2-4-1$ Nishi-Shinjuku |
| Tsimshatsui, Kowloon | Shinjuku-Ku, Tokyo 163 Japan |
| Hong Kong | TEL: (81) 03-3345-8911 |
| TEL: (852) 3-723-6339 |  |

TECHNICAL ASSISTANCE IS AVAILABLE FROM THE FOLLOWING SALES OFFICES:

| UNITED STATES | CALIFORNIA | San Jose . . . . . . . . . . . . . . . . . . 408-995-7322 Woodland Hills. . . . . . . . . . . 818-992-0686 |
| :---: | :---: | :---: |
|  | FLORIDA | Melbourne . . . . . . . . . . . . . . . . . 407-723-0501 |
|  | GEORGIA | Duluth. . . . . . . . . . . . . . . . . . . . 404-476-2035 |
|  | ILLINOIS | Schaumburg. . . . . . . . . . . . . . . . 708-240-3480 |
|  | NEW JERSEY | Voorhees . . . . . . . . . . . . . . . . . 609-751-3425 |
|  | NEW YORK | Great Neck. . . . . . . . . . . . . . . . 516-829-9441 |
| INTERNATIONAL | FRANCE | Paris. . . . . . . . . . . . . . . . . . . . 33-1-346-54046 |
|  | GERMANY | Munich . . . . . . . . . . . . . . . . . . . 49-8-963-8130 |
|  | HONG KONG | Kowloon . . . . . . . . . . . . . . . . . . 852-723-6339 |
|  | ttaly | Milano . . . . . . . . . . . . . . . . . . . . 39-2-262-0761 |
|  | JAPAN | Tokyo . . . . . . . . . . . . . . . . . . . . . 81-33-345-8911 |
|  | KOREA | Seoul . . . . . . . . . . . . . . . . . . . . . 82-2-551-0931 |
|  | SINGAPORE | Singapore. . . . . . . . . . . . . . . . . 65-291-0203 |
|  | UNITED KINGDOM | Camberley . . . . . . . . . . . . . . . . 44-2-766-86886 |

Camberley
44-2-766-86886



\begin{tabular}{|c|c|c|}
\hline NORTH CAROLINA Harris Semiconductor 4020 Stirrup Creek Dr. Building 2A, MS/2T08 Durham, NC 27703 TEL: (919) 549-3600 FAX: 9195493660 \& \begin{tabular}{l}
OREGON \\
Northwest Marketing Assoc. \\
Suite 330 \\
6975 SW Sandburg Road \\
Portland, OR 97223 \\
TEL: (503) 620-0441 \\
FAX: 5036842541
\end{tabular} \& Corporate Atrium il Suite 140 10701 Corporate Dr. Stafford, TX 77477 TEL: (713) 240-6082 FAX: 7132406094 \\
\hline \begin{tabular}{l}
New Era Sales \\
Suite 203 \\
1110 Navajo Dr. Raleigh, NC 27609 \\
TEL: (919) 878-0400 \\
FAX: 9198788514
\end{tabular} \& \begin{tabular}{l}
PENNSYLVANIA \\
Giesting \& Associates 471 Walnut Street Pittsburgh, PA 15238 TEL: (412) 828-3553 FAX: 4128286160
\end{tabular} \& \begin{tabular}{l}
Compass Mktg. \& Sales, Inc. \\
Suite 320 \\
5 Triad Center Salt Lake City, UT 84180 \\
TEL: (801) 322-0391 \\
FAX: 801 322-0392
\end{tabular} \\
\hline OHIO Giesting \& Associates P.O. Box 39398 2854 Blue Rock Rd. Cincinnati, OH 45239 TEL: (513) 385-1105 FAX: 5133855069 \& \begin{tabular}{l}
TEXAS \\
Harris Semiconductor \\
* Suite 205 17000 Dallas Parkway Dallas, TX 75248 TEL: (214) 733-0800 FAX: 2147330819
\end{tabular} \& \begin{tabular}{l}
WASHINGTON \\
Northwest Marketing Assoc. \\
Suite 330N \\
12835 Bel-Red Road \\
Bellevue, WA 98005 \\
TEL: (206) 455-5846 \\
FAX: 2064511130
\end{tabular} \\
\hline 26250 Euclid Avenue Cleveland, OH 44132 TEL: (216) 261-9705 FAX: 2162615624 6324 Tamworth Ct. Columbus, OH 43017 \& \begin{tabular}{l}
Nova Marketing \\
Suite 180 \\
8310 Capitol of Texas Hwy. \\
Austin, TX 78731 \\
TEL: (512) 343-2321 \\
FAX: 512 343-2487
\end{tabular} \& WISCONSIN Oasis Sales 1305 N. Barker Rd. Brookfield, WI 53005 TEL: (414) 782-6660 FAX: 4147827921 \\
\hline TEL: (614) 752-5900 FAX: 614 792-6601 \& Suite 174 8350 Meadow Rd. Dallas, TX 75231 \& \\
\hline \begin{tabular}{l}
OKLAHOMA \\
Nova Marketing Suite 1339 8125D East 51st Street Tulsa, OK 74145 TEL: (800) 826-8557 TEL: (918) 660-5105 FAX: 9186653815
\end{tabular} \& TEL: (214) \(265-4600\)
FAX: 2142654688

*Field Application \& Assistance Available <br>
\hline
\end{tabular}

## North American Authorized Distributors and Corporate Offices

## Alliance Electronics

20 Custom House St.
Boston, MA 02110
TEL: (617) 261-7988
FAX: (617) 261-7987

## Arrow/Schweber

Electronics Group 25 Hub Dr.
Melville, NY 11747
TEL: (516) 391-1300
FAX: 5163911644
Electronics Marketing
Corporation (EMC) 1150 West Third Avenue Columbus, OH 43212
TEL: (614) 299-4161
FAX: 6142994121
Farnell Electronic Services
(Formerly ITT Multicomponents) 300 North Rivermede Rd.
Concord, Ontario
Canada L4K $2 Z 4$
TEL: (416) 798-4884
FAX: 4167984889

Gerber Electronics 128 Carnegie Row Norwood, MA 02062 TEL: (617) 769-6000, x156 FAX: 6177628931
Hamilton Hallmark 10950 W. Washington Blvd. Culver City, CA 90230 TEL: (310) 558-2000 FAX: 3105582809 (Mil) FAX: 3105582076 (Com)
Newark Electronics 4801 N. Ravenswood Chicago, IL 60640
TEL: (312) 784-5100
FAX: 312 275-9596

Wyle Laboratories (Commercial Products) 3000 Bowers Avenue Santa Clara, CA 95051 TEL: (408) 727-2500 FAX: 408 988-2747
Zeus Electronics, An Arrow Company 100 Midland Avenue Pt. Chester, NY 10573 TEL: (914) 937-7400 TEL: (800) $52-\mathrm{HI}-\mathrm{REL}$ FAX: 914 937-2553
Obsolete Products:
Rochester Electronic 10 Malcom Hoyt Drive Newburyport, MA 01950 TEL: (508) 462-9332 FAX: 5084629512

Hamilton Hallmark and Zeus are the only authorized North American distributors for stocking and sale of Harris Rad Hard Space products.

| ALABAMA | Rancho Cordova <br> TEL: (916) 638-5282 | CONNECTICUT <br> Alliance Electronics, inc. <br> Shelton <br> TEL: (203) 926-0087 | Newark Electronics, Inc. Chicago <br> TEL: (312) 907-5436 |
| :---: | :---: | :---: | :---: |
| Arrow/Schweber |  |  |  |
| Huntsville | San Diego <br> TEL: (619) 565-9171 |  |  |
| TEL: (205) 837-6955 |  |  | Wyle Laboratories |
| Hamilion Hallmark | Santa Clara <br> TEL: (408) 727-2500 | Arrow/Schweber <br> Wallingford <br> TEL: (203) 265-7741 | Schaumburg <br> TEL: (708) 303-1040 |
| TEL: (205) 837-8700 | Zeus, An Arrow Company |  | Zeus, An Arrow Company |
| Wyie Laboratories Huntsville | Calabasas | Hamilton Halimark Danbury | $\begin{aligned} & \text { Itasca } \\ & \text { TEL: 708) 250-0500 } \end{aligned}$ |
| TEL: 205) 830-1119 | San Jose | TEL: (203) 271-2844 |  |
| Zeus, An Arrow Company | TEL: (408) 629-4789 | Zeus, An Arrow Company | Arrow/Schweber |
| Huntsville | TEL: (800) 52-HI-REL | Wallingiord | Indianapolis |
| TEL: (205) 837-6955 | Yorba Linda | TEL: (203) 265-7741 | TEL: (317) 299-2071 |
| ARIZONA <br> Alliance Electronics, Inc. Gilbert TEL: (602) 813-0233 | TEL: (800) 52-HI-REL | FLORIDA | Hamilton Hallmark |
|  |  | Alliance Electronics, Inc. | Indianapolis TEL: (317) 872-8875 |
|  | CANADA <br> Arrow/Schweber Burnaby, British Columbia TEL: (604) 421-2333 | TEL: (813) 831-7972 |  |
|  |  | Arrow/Schweber | IOWA |
| Scottsdale TEL: (602) 483-9400 |  | Arrow/Schweber <br> Deerfield Beach | Arrow/Schweber Cedar Rapids |
| Arrow/Schweber Tempe <br> TEL: (602) 431-0030 | Dorval, Quebec <br> TEL: (514) 421-7411 | TEL: (305) 429-820 | TEL: (319) 395-7230 |
|  | Nepan, Ontario <br> TEL: (613) 226-6903 | TEL: (407) 333-9300 | Hamilton Hallmark Cedar Rapids |
| Hamilton Hallmark Phoenix TEL: (602) 437-1200 |  | Hamilton Hallmark | TEL: (319) 362-4757 |
|  | Mississagua, Ontario TEL: (416) 670-7769 | TEL: (305) 484-5482 | Zeus, An Arrow Company Cedar Rapids |
| Wyle Laboratories <br> Phoenix <br> TEL: (602) 437-2088 | Farnell Electronic Services Burnaby, British Columbia TEL: (604) 421-6222 | Orlando <br> TEL: (407) 657-3300 | TEL.: (319) 395-7230 |
|  |  | St. Petersburg | KANSAS |
| Zeus, An Arrow Company Tempe TEL: (602) 431-0030 | Calgary, Alberta TEL: (403) 273-2780 | TEL: (813) 541-7440 | Arrow/Schweber |
|  |  | Wyle Laboratories | Lenexa <br> TEL: (913) 541-9542 |
|  | Concord, Ontario TEL: (416) 738-1071 | Fort Lauderdale <br> TEL: (305) 420-0500 | Hamilton Halimark |
| CALIFORNIA <br> Alliance Electronics, Inc. Santa Clarita TEL: (805) 297-6204 | V. St. Laurent, Quebec <br> TEL: (514) 335-7697 | St. Petersburg TEL: (813) 530-3400 | Kansas City <br> TEL: (913) 888-4747 |
|  | Nepean, Ontario <br> TEL: (613) 596-6980 | Zeus, An Arrow Company Lake Mary | MARYLAND |
| Arrow/Schweber Calabasas <br> TEL: (818) 880-9686 | Winnipeg, Manitoba TEL: (204) 786-2589 | TEL: (407) 333-3055 TEL: (800) $52-\mathrm{Hi}$-REL | $\begin{aligned} & \text { Columbia } \\ & \text { TEL: (301) } 596-7800 \end{aligned}$ |
| Invine <br> TEL: (714) 587-0404 | Hamilton Hallmark <br> Montreal <br> TEL: (514) 335-1000 | GEORGIA Arrow/Schweber Duluth | Hamilton Hallmark Baltimore <br> TEL: (410) 988-9800 |
| San Diego <br> TEL: (619) 565-4800 | Ottawa <br> TEL: (613) 226-1700 | TEL: (404) 497-1300 | Wyle Laboratories Columbia |
| San Jose TEL: (408) | Vancouver, B.C. <br> TEL.: (604) 420-4101 | Hamilton Halimark Atlanta <br> TEL: (404) 623-5475 | TEL: (301) 490-2170 |
|  |  |  | Zeus, An Arrow Company |
| Hamilton Hallmark <br> Costa Mesa <br> TEL: (714) 641-4100 | Toronto <br> TEL: (416) 795-3859 | Wyle Laboratories Duluth TEL: (404) 418-0380 | Columbia ${ }^{\text {TEL: }}$ (301) $596-7800$ |
| Los Angeles <br> TEL: (818) 594-0404 | COLORADO <br> Arrow/Schweber Englewood TEL: (303) 799-0258 | Zeus, An Arrow Company Atlanta <br> TEL: (404) 497-1300 | MASSACHUSETTS <br> Alliance Electronics, Inc. Winchester TEL: (617) 756-1910 |
| Sacramento <br> TEL: (916) 624-9781 |  |  |  |
| San Diego <br> TEL: (619) 571-7540 <br> Sunnyvale | Hamilton Hallmark Denver TEL: (303) 790-1662 | ILLINOIS <br> Alliance Electronics, Inc. Vernon Hills | Arrow/Schweber <br> Wilmington <br> TEL: (508) 658-0900 |
| TEL: (408) 743-3300 | Colorado Springs | TEL: (708) 949-9890 | Gerber |
| Wyle Laboratories Calabasas TEL: (818) 880-9000 | Wyle Laboratories <br> Thornton <br> TEI : (303) 457-9953 | Arrow/Schweber Itasca <br> TEL: (708) 250-0500 | Norwood <br> TEL: (617) 769-6000 <br> Hamilton Hallmark |
| Irvine <br> TEL: (714) 863-9953 | TEL: (303) 457-9953 | Hamilton Hallmark Chicago <br> TEL: (708) 860-7780 | Boston TEL: (508) 532-9808 |
|  |  |  | Wyle Laboratories Burlington (617) 272-7300 |



| European Sales Headquarters Harris S.A. Mercure Center 100, Rue de la Fusee 1130 Brussels, Belgium TEL: 3222462111 FAX: 3222462205 / . . 09 | Erwin W. Hildebrandt Nieresch 32 <br> D - 48301 Nottuln-Darup <br> TEL: 4925026065 <br> FAX: 4925021889 <br> TWX: 892565 <br> Hartmut Welte | SPAIN <br> Elcos S. L. <br> c/ Avd. de Valladolid 55 <br> 2, inter. 1 <br> SP - 28008 Madrid <br> TEL: 3415417510 <br> FAX: 3415417511 | Laser Electronics <br> Ballynamoney Greenore <br> Co. Louth, Ireland TEL: 3534273165 FAX: 3534273518 TWX: 43679 |
| :---: | :---: | :---: | :---: |
| AUSTRIA <br> Eurodis Electronics GMBH Lamezanstrasse 10 A-1232 Wein TEL: 431610620 | D - 88677 Markdorf TEL: 49754472555 FAX: 49754472555 | TURKEY EMPA Elektronik Mamulleri Pazarlama AS | S.M.D. <br> 182 Hall Lane <br> Aspull, Wigan Lancs WN2 2SS <br> TEL: 4494254867 <br> FAX: 44942525317 |
| FAX: 43161062151 | ISRAEL <br> Aviv Electronics Ltd <br> Hayetzira Street, 4 Ind. Zone <br> IS - Ra'anana 43651 <br> PO Box 2433 <br> IS - Ra'anana 43100 <br> TEL: 9729983232 <br> FAX: 9729916510 <br> TWX: 33572 | Besyol Londra Asfalti TK - 34630 Sefakoy/ Istanbul | Stuart Electronics Ltd. Phoenix House |
| ```DENMARK Delco AS Titangade 15 DK - 2200 Copenhagen N TEL: 4535821200 FAX: \(4535 \mathbf{8 2} 1205\)``` |  | TEL: 9015993050 <br> FAX: 9015985353 <br> TWX: 21137 <br> UNITED KINGDOM <br> Harris Semiconductor Ltd <br> * Riverside Way | Bothwell Road Castlehill, Carluke Lanarkshire ML8 5UF TEL: 4455551566 FAX: 4455551562 TWX: 777404 |
| FINLAND <br> Teknokit OY <br> Reinikkalan Kartano SF - 51200 Kangasniemi <br> TEL: 35859432031 <br> FAX: 35859432367 | ITALY <br> Harris SRL <br> * Viale Fulvio Testi, 126 20092 Cinisello Balsamo <br> TEL: 3922620761 <br> (Disti \& OEM ROSE) <br> TEL: 3922409501 <br> (Disti \& OEM Italy) <br> FAX: 3922486620 <br> 39226222158 (ROSE) <br> TWX: 324019 | UNITED KINGDOM <br> Harris Semiconductor Ltd <br> * Riverside Way Camberley Surrey GU15 3YQ TEL: 44276686886 FAX: 44276682323 |  |
| FRANCE <br> Harris Semiconducteurs SARL |  | European Authorized Distributors |  |
| * 2-4, Avenue de l'Europe F - 78140 Velizy <br> TEL: 33134654080 (Dist) <br> TEL: 33134654027 (Sales) <br> FAX: 33139464054 <br> TLX: 697060 |  | AUSTRIA <br> Eurodis Electronics GmbH <br> Lamezanstrasse 10 <br> A - 1232 Wien <br> TEL: 431610620 <br> FAX: 43161062151 | FRANCE <br> 3D <br> ZI des Glaises 6/8 rue Ambroise Croizat F - 91127 Palaiseau Cedex TEL: 33164472929 |
| Unirep <br> Z. I. De La Bonde 1BIS Rue Marcel Paul F - 91300 Massy <br> TEL: 33169200364 <br> FAX: 33169200061 | NETHERLANDS <br> Harris Semiconductor SA Benelux OEM Sales Office Mercuriusstraat 40 NL - 5345 LX Oss TEL: 31412038561 FAX: 31412034419 <br> Auriema Nederland BV Beatrix de Rijkweg, 8 NL-5657 EG Eindhoven TEL: 3140502602 FAX: 3140510255 TWX: 51992 | BELGIUM <br> Diode Belgium <br> * Keiberg II Minervastraat, 14/B2 <br> B-1930 Zaventem | FAX: 33164470084 <br> Arrow Electronique S.A. <br> 73-79, Rue des Solets <br> Silic 585 <br> F - 94663 Rungis Cedex |
| GERMANY <br> Harris Semiconductor GmbH <br> * Putzbrunnerstrasse 69 81739 Muenchen TEL: 4989638130 FAX: 49896376201 TWX: 529051 |  | B-1930 Zaventem <br> TEL: 3227254660 <br> FAX: 3227254511 <br> Eurodis Inelco NV/SA <br> - Avenue des Croix de Guerre 94 B-1120 Brussels <br> TEL: 3222442811 <br> FAX: 3222164606 | TEL: 33149784978 <br> FAX: 33149780596 <br> TLX: 265185 <br> Avnet EMG SA <br> * 81, Rue Pierre Semard F-92320 Chatilion Sous Bagneux <br> TEL: 33149652700 <br> FAX: 33149652738 |
| Harris Semiconductor GmbH <br> Kieler Strasse 55-59 <br> 25451 Quickborn <br> TEL: 494106500204 <br> FAX: 49410668850 <br> TWX: 211582 | PORTUGAL <br> Cristalonica Componentes <br> De Radio E Televisao Lda Rua Bernardim Ribeiro, 25 P-1100 Lisbon TEL: 35113534631 FAX: 35113561755 TWX: 64119 | TWX: 64475 <br> DENMARK <br> Ditz Schweitzer A/S <br> Vallensbaekvej 41 <br> Postboks 5 | TWX: 632247 <br> CCI Electronique <br> * 5, Rue Marcelin Berthelot Zone Industrielle D'Antony BP 92 |
| Harris Semiconductor GmbH <br> Wegener Strasse, 5/1 <br> 71063 Sindelfingen <br> TEL: 497031 8694-0 <br> FAX: 497031873849 <br> TWX: 7265431 | SLOVENIA <br> Avtotehna Celovska 175 Ljubljana TEL: 38661551287 FAX: 386611593341 | DK - 2605 Brondby <br> TEL: 4542453044 <br> FAX: 4542459206 <br> TWX: 33257 <br> FINLAND | F - 92164 Antony Cedex <br> TEL: 33146744700 <br> FAX: 33140969226 <br> TWX: 203881 <br> Tekelec Airtronic <br> * Cite Des Bruyeres |
| Ecker Michelstadt GmbH <br> Koningsberger Strasse, 2 Postfach 3344 <br> D-64720 Michelstadt <br> TEL: 4960612233 <br> FAX: 4960615039 <br> TWX: 4191630 |  | Yleiselektroniikka OY <br> Telercas <br> P.O. Box 63 <br> Luomannotko, 6 <br> SF - 02201 Espoo <br> TEL.: 3580452621 <br> FAX: 358045262231 | Rue Carle Vernet F-92310 Sevres <br> TEL: 33146232425 <br> FAX: 33145072191 <br> TWX: 634018 |

[^9]| Harris Semiconductor Chip Distributors | Sasco GmbH | Diode Components BV Post'bus 7139 | UNITED KINGDOM |
| :---: | :---: | :---: | :---: |
|  | Hermann-Oberth Strasse 16 |  |  |
| Zai De Courtaboeuf | D - 85640 Putzbrunn- | NL - 5605 JC Eindhoven <br> TEL: 3140545430 <br> FAX: 3140535540 | Jubilee House, Jubilee Road Letchworth |
|  | TEL: 498946110 |  |  |
| Avenue Des Andes | FAX: 49894611270 |  | Hertordshire SG6 1QH <br> TEL: 44462480888 |
| 91952 Les Ulis Cedex | TWX: 529504 | NORWAY | : 44462488 |
| TEL: 33164460650 <br> FAX: 33169284396 TWX: 600333 |  | Hans H. Schive A/S Undelstadlia 27 | TWX: 826505 |
|  | Max-Planck Strasse 1-3 | Postboks 185 | ESD Distribution Ltd |
|  | D-63303 Dreieich |  | Edinburgh Way, Harlow |
|  | L: 4961033048 | N-1371 Asker | Essex CM20 2DE |
| Z. A. De La Tuilerie B. P. 1077 | $\begin{aligned} & \text { FAX: } 496103304201 \\ & \text { TWX: } 417972 \end{aligned}$ | $\text { FAX: } 4766904484$$\text { TWX: } 19124$ | FAX: 44279441687 |
| TEL: 33134771616 |  |  | TWX: 818801 |
| FAX: 33134779579 TWX: 699737 | GREECE | PORTUGAL Cristalonica | Farnell Electronic <br> Components Ltd. <br> Marketing \& Purchasing Div. |
| Hybritech CM (HCM) | Semicon C | Componentes De |  |
| 7, Avenue Juliot Curie | GR - 10564 Athens | Televisao, Lda | Armley Road, Leeds |
| F-17027 LA Rochelle Cedex | TEL: 3013253626 | Rua Bernardim Ribeiro, 25 | West Yorkshire LS12 2QQ |
| TEL: 3346451270 |  | P. 1100 Lisbon | TEL: 44532790101 |
| TWX: 793034 | $\begin{aligned} & \text { FAX: } 3013216063 \\ & \text { TWX:216684 } \end{aligned}$ | TEL: 35113534631 FAX: 35113561755 | FAX: 44532633404 |
|  |  |  | Jermyn Distribution |
| EASTERN COUNTRIES HEV GmbH Halbleiter-Electronic Vertriebs GmbH Alexanderplatz 6 0-10178 Berlin Postfach 90 $0-10173$ Berlin TEL: 49302483400 FAX: 49302483424 TWX: 307011 | Aviv Electronics LtdHayetzira Street 4, Ind. Zone | SPAIN Amitron-Arrow S.A. Avenida Valladolid 47D BAJ0 | Vestry Industrial Estate Sevenoaks |
|  |  |  |  |
|  | IS - 43651 Ra'anana |  | Kent 44732743743 |
|  | PO Box 2433 | SP - 28008 Madrid | FAX: 44732451251 TWX: 95142 |
|  | TEL: 9729983232 FAX: 9729916510 | TEL. 3415420906 |  |
|  |  | TEL: 3415479313 | Macro Marketing Ltd Burnham Lane |
|  |  | EBV Elektronik Vertriebs |  |
|  | Eurelettronica SpA |  | Slough, Berkshire SL1 6LN TEL: 44628604422 |
|  |  | GmbH | FAX: 44628666873 |
| GERMANY <br> Alfred Neye Enatechnik GmbH <br> Schillerstrasse 14 <br> D-25451 Quickborn <br> TEL: 4941066120 <br> FAX: 494106612268 <br> TWX: 213590 | 1-20090 Assago (MI) <br> TEL: 392457841 <br> FAX: 3924880275 | Calle Maria Tubau 6 SP - 28049 Madrid TEL: 3413588608 FAX: 3413588560 | WX: 847945 |
|  |  |  | Micromark Electronics Ltd. Boyn Valley Road |
|  |  |  |  |
|  | EBV Elektronik SRL Via Frova, 34 |  | Berkshire SL6 4DT |
|  | F-20092 Cinisello Balsamo (MI) | SWEDEN | TEL: 4462876176 |
|  | TEL: 392660.17111 | Bexab Sweden ABP.O. Box 523 | FAX: 44628783799 TWX: 847397 |
|  | FAX: 392660.17020 |  |  |
| Avnet/E2000 <br> Stahlgruberring, 12 <br> D-81829 Muenchen <br> TEL: 49894511001 <br> FAX: 498945110129 <br> TWX: 522561 | Lasi Elettronica SpA <br> Viale Fulvio Testi 280 <br> 1-20126 Milano <br> TEL: 39266101370 <br> FAX: 39266101385 <br> TWX: 352040 | Kemistvagen, 10A S - 18325 Taby TEL: 4686308800 FAX: 4687327058 | Thame Components <br> Thame Park Rd. <br> Thame, Oxfordshire OX9 3UQ <br> TEL: 44844261188 <br> FAX: 44844261681 <br> TWX: 837917 |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |
|  |  | SWITZERLAND <br> BASiX fur Elektronik AG |  |
| HED Heinrich Electronic Distribution GmbH <br> Steeler Strasse 529 <br> D - 45276 Essen <br> TEL: 492015636225 <br> FAX: 492015636268 <br> Indeg Industrie Elektronik <br> GmbH <br> Postfach 1563 <br> D-66924 Pirmasens <br> Emil Kommerling Str. 5 <br> D-66954 Pirmasens <br> TEL: 49633194065 <br> FAX: 49633194064 <br> TWX: 452269 | Silverstar Ltd. <br> Viale Fulvio Testi 280 <br> 1-20126 Milano <br> TEL: 392661251 <br> FAX: 39266101359 <br> TWX: 332189 |  | Harris Semiconductor <br> Chip Distributors <br> Die Technology Ltd. Corbrook Rd., Chadderton Lancashire OL. 9 9SD TEL: 44616263827 FAX: 44616274321 TWX: 668570 |
|  |  | Hardturmstrasse 181 |  |
|  |  | Postfach |  |
|  |  | CH - 8010 Zurich |  |
|  |  | TEL: 4112761111 |  |
|  |  | FAX: 4112761234 |  |
|  |  | Eurodis Electronic AG <br> Bahnstrasse 58/60 <br> CH - 8105 Regensdorf <br> TEL: 4118433111 <br> FAX: 4118433910 |  |
|  | NETHERLANDS <br> * Auriema Nederland BV Beatrix de Rijkweg 8 NL - 5657 EG Eindhoven TEL: 3140502602 FAX: 3140510255 TWX: 51992 |  | Rood Technology <br> Test House Mill Lane, Alton <br> Hampshire GU34 2QG <br> TEL: 4442088022 <br> FAX: 4442087259 <br> TWX: 858456 |
|  | * Diode Components BV Coltbaan 17 <br> NL - 3439 NG Nieuwegein <br> TEL.: 31340291234 <br> FAX: 31340235924 | Elektronik Mamulleri Pazarlama AS Besyol Londra Asfalti TK - 34630 Sefakoy/ Istanbul TEL: 9015993050 FAX: 9015985353 TWX: 21137 |  |

[^10]

## We're Backing You Up with Products, Support, and Solutions!

Signal Processing

- Linear
- Custom Linear
- Data Conversion
- Interface
- Analog Switches
- Multiplexers
- Filters
- DSP
- Telecom


## Power Products

- Power MOSFETs
- IGBTs
- MCTs
- Bipolar
- Transient Voltage

Suppressors

- MOVs
- Rectifiers
- Surgectors
- MLVs
- Intelligent Discretes

Intelligent Power

- PoweriCs
- Power ASICs
- Hybrid Programmable Switches
- Full-Custom High Voltage ICs

Military/Aerospace Products

- Microprocessors and Peripherals
- Memories
- Analog ICs
- Digital ICs
- Discrete Power
- Bipolar
- MOSFET
- IGBTs
- MOVs


## ASICs

- Full-Custom
- Analog Semicustom
- Mixed-Signal
- ASIC Design Software

Digital

- CMOS Microprocessors and Peripherals
- CMOS Microcontrollers
- CMOS Logic


## Rad-Hard Products

- Microprocessors and

Peripherals

- Memories
- Analog ICs
- Digital ICs
- Discrete Power
- Bipolar
- MOSFET
- ASICs
- ESA SCC 9000 and Class S Screening

Military/Aerospace Programs

- Strategic and Space

Programs

- Military ASIC Programs


# We＇re Backing You Up with Products，Support，and Solutions！ 

Signal Processing
－Linear
－Custom Linear
－Data Conversion
－Interface
－Analog Switches
－Multiplexers
－Filters
－DSP
－Telecom

## Power Products

－Power MOSFETS
－IGBTs
－MCTs
－Bipolar
－Transient Voltage
Suppressors
－MOVs
－Rectifiers
－Surgectors
－MLVs
－Intelligent Discretes

Intelligent Power
－Power ICs
－Power ASICs
－Hybrid Programmable Switches
－Full－Custom High Voltage ICs

## Military／Aerospace Products

－Microprocessors and Peripherals
－Memories
－Analog ICs
－Digital ICs
－Discrete Power
Bipolar
MOSFET
IGBTs．
MOVs

## ASICs

－Full－Custom
－Analog Semicustom
－Mixed－Signal
－ASIC Design Software

Digital
－CMOS Microprocessors and Peripherals
－CMOS Microcontrollers
－CMOS Logic

## Rad－Hard Products

－Microprocessors and Peripherals
－Memories
－Analog ICs
－Digital ICs
－Discrete Power
－Bipolar MOSFET
－ASICs
－ESA SCC 9000 and Class S Screening

Military／Aerospace Programs
－Strategic and Space
Programs
－Military ASIC Programs


[^0]:    DECl॰MATE ${ }^{\text {TM }}$ is a Trademark of Harris Corporation

[^1]:    NOTE: Bold Type Designates a New Product from Harris.

[^2]:    CAUTION: These devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be foliowed.

[^3]:     rating is $8 \mathrm{~mA} / \mathrm{MHz}$.

[^4]:    2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
    3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
[^5]:    2. $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position
[^6]:    OFFB0-7: Least significant bits of Offset Register B.

[^7]:    CAUTION: These devices are sensitive to electrostatic discharge. Users should follow proper I.C. Handing Procedures.

[^8]:    Copyright Notice: Copyright 1989, TKC. Reprinted by Harris Semiconductor, April 1989, with permission of TKC.

[^9]:    * Field Application Assistance Available

[^10]:    * Field Application Assistance Available

