Data Sheet May 1999 File Number 2785.5 # Digital Filter 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 9x9 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 30MHz. The effective multiply-accumulate (mac) rate is 240MHz. 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 30MHz 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 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. #### Features - · Eight Filter Cells - · 0MHz to 30MHz 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 | TEMP.<br>RANGE (°C) | PACKAGE | PKG. NO. | |---------------|---------------------|---------------|------------| | HSP43891VC-20 | 0 to 70 | 100 Lead MQFP | Q100.14x20 | | HSP43891VC-25 | 0 to 70 | 100 Lead MQFP | Q100.14x20 | | HSP43891VC-30 | 0 to 70 | 100 Lead MQFP | Q100.14x20 | | HSP43891JC-20 | 0 to 70 | 84 Lead PLCC | N84.1.15 | | HSP43891JC-25 | 0 to 70 | 84 Lead PLCC | N84.1.15 | | HSP43891JC-30 | 0 to 70 | 84 Lead PLCC | N84.1.15 | | HSP43891GC-20 | 0 to 70 | 85 Pin CPGA | G85.A | | HSP43891GC-25 | 0 to 70 | 85 Pin CPGA | G85.A | | HSP43891GC-30 | 0 to 70 | 85 Pin CPGA | G85.A | # **Pinout** #### 85 PIN GRID ARRAY (PGA) | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | _ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | |---|-----------------|-----------------|-----------------|-----------------|-------|-----------------|-----------------|-------|-----------------|-----------------|-----------------|---|----------------------|-----------------|----------------------|-----------------|-------------|-----------------------|------------------------|------------|------------|-----------------|-----------------------| | Α | v <sub>ss</sub> | COENB | V <sub>CC</sub> | RESET | DIN7 | DIN6 | DIN3 | DIN0 | CIN8 | v <sub>cc</sub> | v <sub>ss</sub> | L | O<br>DCM1 | O<br>SUM23 | O<br>SUM22 | O<br>SUM21 | O<br>SUM18 | O<br>SUM14 | O<br>1 V <sub>CC</sub> | O<br>SUM13 | O<br>vss | O<br>SUM11 | O<br>SUM9 | | В | v <sub>cc</sub> | COUT7 | COUT8 | ERASE | DIN8 | DIN1 | DIN2 | CIENB | CIN7 | CIN6 | CIN4 | к | O<br>SENBH | O<br>SUM24 | $O_{v_{ss}}$ | $_{v_{cc}}^{O}$ | O<br>SUM19 | $\mathop{O}_{v_{SS}}$ | O<br>SUM15 | O<br>SUM12 | O<br>SUM10 | O<br>SUM8 | O<br>SUM6 | | С | COUT5 | COUT6 | ALIGN<br>PIN | | DIENB | DIN5 | DIN4 | | | CIN5 | CIN3 | J | O <sub>vcc</sub> | O<br>SUM25 | | | O<br>SUM20 | O<br>SUM17 | O<br>SUM16 | <b>s</b> | | O<br>SUM7 | O<br>v <sub>ss</sub> | | D | соитз | COUT4 | | | | | | | | CIN2 | v <sub>cc</sub> | н | O<br>ADR1 | O<br>ADR0 | | | | | | | | O<br>SUM5 | O<br>SUM4 | | E | COUT1 | V <sub>SS</sub> | COUT2 | | не | P43 | <b>201</b> | | CIN1 | CIN0 | SENBL | G | O<br>ADR2 | O<br>DCM0 | O | | HSI | P43 | 891 | | O<br>SUM1 | O<br>SUM3 | O<br>SUM2 | | F | V <sub>SS</sub> | COUTO | SHADD | | | OP VIE | | | ѕимо | v <sub>cc</sub> | V <sub>SS</sub> | F | O<br>vss | COUTO | SHADD | ) | BOT1 | OM V | | | O<br>SUM0 | O | $_{v_{ss}}^{O}$ | | G | ADR2 | DCM0 | CLK | | PIN | IS DO | WN | | SUM1 | SUM3 | SUM2 | E | O<br>COUT1 | $_{v_{ss}}^{O}$ | O<br>COUT2 | | | | | | O<br>CIN1 | O<br>CIN0 | O<br>SENBL | | н | ADR1 | ADR0 | | | | | | | | SUM5 | SUM4 | D | COUT3 | O<br>COUT4 | | | | | | | | O<br>CIN2 | O | | J | v <sub>cc</sub> | SUM25 | | | SUM20 | SUM17 | SUM16 | | | SUM7 | V <sub>SS</sub> | С | COUTS | COUT6 | O<br>ALIGN<br>PIN | | O<br>DIENB | O<br>DIN5 | O<br>DIN4 | | | O<br>CIN5 | O<br>CIN3 | | ĸ | SENBH | SUM24 | V <sub>SS</sub> | v <sub>cc</sub> | SUM19 | V <sub>SS</sub> | SUM15 | SUM12 | SUM10 | SUM8 | SUM6 | В | O<br>v <sub>cc</sub> | COUTT | 0 | O<br>ERASI | O<br>E DIN8 | O<br>DIN1 | O<br>DIN2 | O<br>CIENB | O<br>CIN7 | O<br>CIN6 | O<br>CIN4 | | L | DCM1 | SUM23 | SUM22 | SUM21 | SUM18 | SUM14 | V <sub>CC</sub> | SUM13 | V <sub>SS</sub> | SUM11 | SUM9 | Α | ●<br>V <sub>SS</sub> | O<br>COENB | O<br>v <sub>cc</sub> | O<br>RESET | O<br>DIN7 | O<br>DIN6 | O<br>DIN3 | O<br>DIN0 | CIN8 | $_{v_{cc}}^{O}$ | $\mathop{O}_{v_{SS}}$ | # 84 LEAD PLASTIC LEADED CHIP CARRIER (PLCC) # Pinout (Continued) #### 100 LEAD MQFP TOP VIEW # Pin Description | SYMBOL | PIN<br>NUMBER | TYPE | | | NAME AND FUNCTION | | | | | | | |-----------------|---------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | V <sub>CC</sub> | B1, J1, A3, K4,<br>L7, A10, F10,<br>D11 | | +5 power su | upply input | | | | | | | | | V <sub>SS</sub> | A1, F1, E2, K3,<br>K6, L9, A11,<br>F11, J11 | | Power supp | ly ground i | input. | | | | | | | | CLK | G3 | I | The CLK in | out provide | es the DF system sample clock. The maximum | clock frequency is 30MHz. | | | | | | | DIN0-8 | A5-8, B5-7, C6,<br>C7 | I | through the ables loading | se pins to | e the data sample input bus. Nine-bit data sa<br>the X register of each filter cell of the DF simu<br>s synchronous on the rising edge of the clock s | Itaneously. The DIENB signal enignal. | | | | | | | | | | | The data samples can be either 9-bit two's complement or 8-bit unsigned values. For 9-bit two's complement values, DIN8 is the sign bit. For 8-bit unsigned values, DIN8 must be held at logical zero. | | | | | | | | | DIENB | C5 | I | CLK signal present on CLK edge value latched insiduring the c | low on this input enables the data sample input bus (DIN0-8) to all the filter cells. A rising edge of the LK signal occurring while DIENB is low will load the X register of every filter cell with the 9-bit value resent on DIN0-8. A high on this input forces all the bits of the data sample input bus to zero; a rising LK edge when DIENB is high will load the X register of every filter cell with all zeros. This signal is tched inside the device, delaying its effect by one clock internal to the device. Therefore it must be low uring the clock cycle immediately preceding presentation of the desired data on the DIN0-8 inputs. Deilled operation is shown in later timing diagrams. | | | | | | | | | CIN0-8 | A9, B9-11, C10,<br>C11, D10, E9,<br>E10 | I | into the C re | These nine inputs are used to input the 9-bit coefficients. The coefficients are synchronously loaded into the C register of filter CELL0 if a rising edge of CLK occurs while $\overline{\text{CIENB}}$ is low. The $\overline{\text{CIENB}}$ signal is delayed by one clock as discussed below. | | | | | | | | | | | | The coefficients can be either 9-bit two's complement or 8-bit unsigned values. For 9-bit two's complement values, CIN8 is the sign bit. For 8-bit unsigned values, CIN8 must be held at logical zero. | | | | | | | | | | ALIGN PIN | C3 | | Used for ali | gning chip | on socket or printed circuit board. This pin mus | t be left as a no connect in circuit. | | | | | | | CIENB | B8 | I | filter cell ac CIENB is lot their inputs. high on this This signal clock cycle | cording to<br>w will load<br>This provi<br>input free<br>is latched<br>mmediate | ables the C register of every filter cell and the the state of the DCM0-1 inputs. A rising edge of the C register and appropriate D registers we des the mechanism for shifting coefficients from the contents of the C register and the D register and the D register and the DF. The preceding presentation of the desired coefficillater timing diagrams. | of the CLK signal occurring while ith the coefficient data present at a cell to cell through the device. A egisters, ignoring the CLK signal. herefore it must be low during the | | | | | | | COUT0-8 | B2, B3, C1, D1,<br>E1, C2, D2, F2,<br>E3 | 0 | are enabled | by the CC<br>e to coeffic | e outputs are used to output the 9-bit coefficients<br>DENB signal low. These outputs may be tied to<br>cients, or they may be tied to the CIN0-8 inputs | the CIN0-8 inputs of the same DF | | | | | | | COENB | A2 | I | A low on the in their high | | input enables the COUT0-8 outputs. A high on se state. | this input places all these outputs | | | | | | | DCM0-1 | L1, G2 | I | These two i | nputs dete | ermine the use of the internal decimation registe | ers as follows: | | | | | | | | | | DCM1 | DCM0 | DECIMATION FUNCTION | | | | | | | | | | | 0 | 0 | Decimation registers not used | | | | | | | | | | | 0 | 1 | One decimation register is used | | | | | | | | | | | 1 0 Two decimation registers are used | | | | | | | | | | | | | 1 1 Three decimation registers are used | | | | | | | | | | | | | When no deduction | ecimation i<br>register is | from cell to cell at a rate determined by the nun<br>registers are used, coefficients move from cell<br>used, coefficients move from cell to cell on eve<br>ed by one clock internal to the device. | to cell on each clock. When one | | | | | | #### Pin Description (Continued) | SYMBOL | PIN<br>NUMBER | TYPE | NAME AND FUNCTION | |---------|------------------------------------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SUM0-25 | F9, G9-G11,<br>H10, H11, J2,<br>J5-J7, J10, K2,<br>K5, K7-K11,<br>L2-L6, L8, L10,<br>L11 | 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 ADR0-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{SENBH}\$ and \$\overline{SENBL}\$ enable the most significant and least significant bits of the SUM0-25 result respectively. Both \$\overline{SENBH}\$ and \$\overline{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. | | 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 | I | A low on this input enables result bits SUM0-15. A high on this input places these bits in their high impedance state. | | ADR0-2 | G1, H1, H2 | I | These three inputs select the one cell whose accumulator will be read through the output bus (SUM0-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 ADR0-2 remains at the same address for more than one clock, the output at SUM0-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADR0-2 selects the cell, will be output. This does not hinder normal operation since the ADR0-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 | I | 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. | | RESET | A4 | I | 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 | I | A low on this input synchronously clears the cell accumulator selected by the ADR0-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 (CIN0-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 DCM0 and DCM1. The output signals (COUT0-8) are connected to the CIN0-8 inputs of the next cell to its right. The COENB input signal enables the COUT0-8 outputs of the right most cell to the COUT0-8 pins of the device. The C and D registers are enabled for loading by $\overline{\text{CIENB}}$ . Loading is synchronous with CLK when $\overline{\text{CIENB}}$ is low. Note that $\overline{\text{CIENB}}$ is latched internally. It enables the register for loading after the next CLK following the onset of $\overline{\text{CIENB}}$ low. Actual loading occurs on the second CLK following the onset of $\overline{\text{CIENB}}$ low. Therefore $\overline{\text{CIENB}}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CIN0-8 inputs. In most basic FIR operations, $\overline{\text{CIENB}}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When $\overline{\text{CIENB}}$ is high, the coefficients are frozen. The C and D registers are cleared synchronously under control of $\overline{\text{RESET}}$ , which is latched and delayed exactly like $\overline{\text{CIENB}}$ . The output of the C register (C0-8) is one input to 9 x 9 multiplier. The other input to the 9 x 9 multiplier comes from the output of the X register. This register is loaded with a data sample from the device input signals DIN0-8 discussed above. The X register is enabled for loading by $\overline{\text{DIENB}}$ . Loading is synchronous with CLK when $\overline{\text{DIENB}}$ is low. Note that $\overline{\text{DIENB}}$ is latched internally. It enables the register for loading after the next CLK following the onset of $\overline{\text{DIENB}}$ low. Actual loading occurs on the second CLK following the onset of $\overline{\text{DIENB}}$ low; therefore, $\overline{\text{DIENB}}$ must be low during the clock cycle immediately preceding presentation of the data sample on the DIN0-8 inputs. In most basic FIR operations, $\overline{\text{DIENB}}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When $\overline{\text{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, MREG0 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 ADR0-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-of-products 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 ADR0-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 | RESET 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 ADR0-2 inputs is cleared. | | 0 | 0 | Both RESET and 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 ADR0-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 SUM0-25 bus. The output mux determines whether the cell accumulator selected by ADR0-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 ADR0-2. Otherwise the output mux selects the contents of the output buffer. If the ADR0-2 lines remain at the same address for more than one clock, the output at SUM0-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADR0-2 selects the cell will be output. This does not hinder normal FIR operation since the ADR0-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 SENBH and SENBL signals. A low on SENBL enables bits SUM0-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 9x9 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 sum products are: | | MAXIMUM # | OF TERMS | |-----------------------------------------------------------|-----------|----------| | NUMBER SYSTEM | 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<br>Vector | 2064 | 1028 | | One Unsigned 8-Bit Vector and One Two's Complement Vector | | | | Positive 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, 30MHz 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, $C_N$ , enters the DF on the left and moves from left to right through the cells. The data sample sequence, $X_N$ , 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 | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR | |-----|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|---------------------------| | 0 | C <sub>7</sub> x X <sub>0</sub> | 0 | 0 | 0 | - | - | - | - | - | | 1 | +C <sub>6</sub> x X <sub>1</sub> | C <sub>7</sub> x X <sub>1</sub> | 0 | 0 | - | - | - | - | - | | 2 | +C <sub>5</sub> x X <sub>2</sub> | +C <sub>6</sub> x X <sub>2</sub> | C <sub>7</sub> x X <sub>2</sub> | 0 | - | - | - | - | - | | 3 | +C <sub>4</sub> x X <sub>3</sub> | +C <sub>5</sub> x X <sub>3</sub> | +C <sub>6</sub> x X <sub>3</sub> | C <sub>7</sub> x X <sub>3</sub> | - | - | - | - | - | | 4 | +C <sub>3</sub> x X <sub>4</sub> | +C <sub>4</sub> x X <sub>4</sub> | +C <sub>5</sub> x X <sub>4</sub> | +C <sub>6</sub> x X <sub>4</sub> | C <sub>7</sub> x X <sub>4</sub> | - | - | - | - | | 5 | +C <sub>2</sub> x X <sub>5</sub> | +C <sub>3</sub> x X <sub>5</sub> | +C <sub>4</sub> x X <sub>5</sub> | +C <sub>5</sub> x X <sub>5</sub> | +C <sub>6</sub> x X <sub>5</sub> | C <sub>7</sub> x X <sub>5</sub> | - | - | - | | 6 | +C <sub>1</sub> x X <sub>6</sub> | +C <sub>2</sub> x X <sub>6</sub> | +C <sub>3</sub> x X <sub>6</sub> | +C <sub>4</sub> x X <sub>6</sub> | +C <sub>5</sub> x X <sub>6</sub> | +C <sub>6</sub> x X <sub>6</sub> | C <sub>7</sub> x X <sub>6</sub> | - | - | | 7 | +C <sub>0</sub> x X <sub>7</sub> | +C <sub>1</sub> x X <sub>7</sub> | +C <sub>2</sub> x X <sub>7</sub> | +C <sub>3</sub> x X <sub>7</sub> | +C <sub>4</sub> x X <sub>7</sub> | +C <sub>5</sub> x X <sub>7</sub> | +C <sub>6</sub> x X <sub>7</sub> | C <sub>7</sub> x X <sub>7</sub> | Cell 0 (Y <sub>7</sub> ) | | 8 | C <sub>7</sub> x X <sub>8</sub> | +C <sub>0</sub> x X <sub>8</sub> | +C <sub>1</sub> x X <sub>8</sub> | +C <sub>2</sub> x X <sub>8</sub> | +C <sub>3</sub> x X <sub>8</sub> | +C <sub>4</sub> x X <sub>8</sub> | +C <sub>5</sub> x X <sub>8</sub> | +C <sub>6</sub> x X <sub>8</sub> | Cell 1 (Y <sub>8</sub> ) | | 9 | +C <sub>6</sub> x X <sub>9</sub> | C <sub>7</sub> x X <sub>9</sub> | +C <sub>0</sub> x X <sub>9</sub> | +C <sub>1</sub> x X <sub>9</sub> | +C <sub>2</sub> x X <sub>9</sub> | +C <sub>3</sub> x X <sub>9</sub> | +C <sub>4</sub> x X <sub>9</sub> | +C <sub>5</sub> x X <sub>9</sub> | Cell 2 (Y <sub>9</sub> ) | | 10 | +C <sub>5</sub> x X <sub>10</sub> | +C <sub>6</sub> x X <sub>10</sub> | C <sub>7</sub> x X <sub>10</sub> | +C <sub>0</sub> x X <sub>10</sub> | +C <sub>1</sub> x X <sub>10</sub> | +C <sub>2</sub> x X <sub>10</sub> | +C <sub>3</sub> x X <sub>10</sub> | +C <sub>4</sub> x X <sub>10</sub> | Cell 3 (Y <sub>10</sub> ) | | 11 | +C <sub>4</sub> x X <sub>11</sub> | +C <sub>5</sub> x X <sub>11</sub> | +C <sub>6</sub> x X <sub>11</sub> | C <sub>7</sub> x X <sub>11</sub> | +C <sub>0</sub> x X <sub>11</sub> | +C <sub>1</sub> x X <sub>11</sub> | +C <sub>2</sub> x X <sub>11</sub> | +C <sub>3</sub> x X <sub>11</sub> | Cell 4 (Y <sub>11</sub> ) | | 12 | +C <sub>3</sub> x X <sub>12</sub> | +C <sub>4</sub> x X <sub>12</sub> | +C <sub>5</sub> x X <sub>12</sub> | +C <sub>6</sub> x X <sub>12</sub> | C <sub>7</sub> x X <sub>12</sub> | +C <sub>0</sub> x X <sub>12</sub> | +C <sub>1</sub> x X <sub>12</sub> | +C <sub>2</sub> x X <sub>12</sub> | Cell 5 (Y <sub>12</sub> ) | | 13 | +C <sub>2</sub> x X <sub>13</sub> | +C <sub>3</sub> x X <sub>13</sub> | +C <sub>4</sub> x X <sub>13</sub> | +C <sub>5</sub> x X <sub>13</sub> | +C <sub>6</sub> x X <sub>13</sub> | C <sub>7</sub> x X <sub>13</sub> | +C <sub>0</sub> x X <sub>13</sub> | +C <sub>1</sub> x X <sub>13</sub> | Cell 6 (Y <sub>13</sub> ) | | 14 | +C <sub>1</sub> x X <sub>14</sub> | +C <sub>2</sub> x X <sub>14</sub> | +C <sub>3</sub> x X <sub>14</sub> | +C <sub>4</sub> x X <sub>14</sub> | +C <sub>5</sub> x X <sub>14</sub> | +C <sub>6</sub> x X <sub>14</sub> | +C <sub>7</sub> x X <sub>14</sub> | +C <sub>0</sub> x X <sub>14</sub> | Cell 7 (Y <sub>14</sub> ) | | 15 | +C <sub>0</sub> x X <sub>15</sub> | +C <sub>1</sub> x X <sub>15</sub> | +C <sub>2</sub> x X <sub>15</sub> | +C <sub>3</sub> x X <sub>15</sub> | +C <sub>4</sub> x X <sub>15</sub> | +C <sub>5</sub> x X <sub>15</sub> | +C <sub>6</sub> x X <sub>15</sub> | C <sub>7</sub> x X <sub>15</sub> | Cell 0 (Y <sub>15</sub> ) | 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, 30MHz 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), MREG0, MREG1, and TREG (Figures 1 and 2). Therefore, the delay from presentation of data and coefficients at the DIN0-8 and CIN0-8 inputs to a sum appearing at the SUM0-25 output is: k + Td, where k = filter length and Td = 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, $Y_N$ , shown in the timing diagram are derived from the sum-of-products equation. $$Y_{N} = \sum_{K=0}^{7} C_{K} X_{N-K}$$ FIGURE 4. HSP43891 30MHz, 8-TAP FIR FILTER TIMING FIGURE 5. HSP43891 30MHz, 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 30MHz sample rate. Using a single device clocked at 30MHz, an FIR filter of over 500 taps can be constructed to operate at less than a 30MHz 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 COUT0-8 outputs of the (i)th DF to the CIN0-8 inputs of the (i+1)th DF. The DIN0-8fs 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. TABLE 2. DATA SEQUENCE INPUT $X_{30} \dots X_9, X_8, X_{22} \dots X_1, X_0$ COEFFICIENT SEQUENCE INPUT $C_0 \dots C_{14}, C_{15}, 0 \dots C_0 \dots C_{14}, C_{15} \longrightarrow HSP43891 \longrightarrow \dots 0, Y_{30} \dots Y_{23}, 0 \dots 0, Y_{22} \dots Y_{15}, 0 \dots 0$ | CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR | | | | |----------|------------------------------------|-----------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|---------------------------|--|--|--| | 6 | C <sub>15</sub> x X <sub>0</sub> | 0 | 0 | 0 | - | - | - | - | - | | | | | 7 | +C <sub>14</sub> x X <sub>1</sub> | C <sub>15</sub> x X <sub>1</sub> | 0 | 0 | - | - | - | - | - | | | | | 8 | +C <sub>13</sub> x X <sub>2</sub> | | C <sub>15</sub> x X <sub>2</sub> | 0 | - | - | - | - | - | | | | | 9 | +C <sub>12</sub> x X <sub>3</sub> | | | C <sub>15</sub> x X <sub>3</sub> | - | - | - | - | - | | | | | 10 | +C <sub>11</sub> x X <sub>4</sub> | | | +C <sub>14</sub> x X <sub>4</sub> | C <sub>15</sub> x X <sub>4</sub> | - | - | - | - | | | | | 11 | +C <sub>10</sub> x X <sub>5</sub> | | | +C <sub>13</sub> x X <sub>5</sub> | | C <sub>15</sub> x X <sub>5</sub> | - | - | - | | | | | 12 | +C <sub>9</sub> x X <sub>6</sub> | | | +C <sub>12</sub> x X <sub>6</sub> | | | C <sub>15</sub> x X <sub>6</sub> | - | - | | | | | 13 | +C <sub>8</sub> x X <sub>7</sub> | | | +C <sub>11</sub> x X <sub>7</sub> | | | | C <sub>15</sub> x X <sub>7</sub> | - | | | | | 14 | +C <sub>7</sub> x X <sub>8</sub> | | | +C <sub>10</sub> x X <sub>8</sub> | | | | +C <sub>14</sub> x X <sub>8</sub> | - | | | | | 15 | +C <sub>6</sub> x X <sub>9</sub> | | | +C <sub>9</sub> x X <sub>9</sub> | | | | +C <sub>13</sub> x X <sub>9</sub> | - | | | | | 16 | +C <sub>5</sub> x X <sub>10</sub> | | | +C <sub>8</sub> x X <sub>10</sub> | | | | +C <sub>12</sub> x X <sub>10</sub> | - | | | | | 17 | +C <sub>4</sub> x X <sub>11</sub> | | | +C <sub>7</sub> x X <sub>11</sub> | | | | +C <sub>11</sub> x X <sub>11</sub> | - | | | | | 18 | +C <sub>3</sub> x X <sub>12</sub> | | | +C <sub>6</sub> x X <sub>12</sub> | | | | +C <sub>10</sub> x X <sub>12</sub> | - | | | | | 19 | +C <sub>2</sub> x X <sub>13</sub> | | | +C <sub>5</sub> x X <sub>13</sub> | | | | +C <sub>9</sub> x X <sub>13</sub> | - | | | | | 20 | +C <sub>1</sub> x X <sub>14</sub> | | | +C <sub>4</sub> x X <sub>14</sub> | | | | +C <sub>8</sub> x X <sub>14</sub> | - | | | | | 21 | +C <sub>0</sub> x X <sub>15</sub> | | | +C <sub>3</sub> x X <sub>15</sub> | | | | +C <sub>7</sub> x X <sub>15</sub> | Cell 0 (Y <sub>15</sub> ) | | | | | 22 | 0 | C <sub>0</sub> x X <sub>16</sub> | ↓ | +C <sub>2</sub> x X <sub>16</sub> | | | | +C <sub>6</sub> x X <sub>16</sub> | Cell 1 (Y <sub>16</sub> ) | | | | | 23 | 0 | 0 | C <sub>0</sub> x X <sub>17</sub> | +C <sub>1</sub> x X <sub>17</sub> | | | | +C <sub>5</sub> x X <sub>17</sub> | Cell 2 (Y <sub>17</sub> ) | | | | | 24 | 0 | 0 | 0 | +C <sub>0</sub> x X <sub>18</sub> | ↓ | | | +C <sub>4</sub> x X <sub>18</sub> | Cell 3 (Y <sub>18</sub> ) | | | | | 25 | 0 | 0 | 0 | 0 | C <sub>0</sub> x X <sub>19</sub> | ↓ | | +C <sub>3</sub> x X <sub>19</sub> | Cell 4 (Y <sub>19</sub> ) | | | | | 26 | 0 | 0 | 0 | 0 | 0 | C <sub>0</sub> x X <sub>20</sub> | ↓ | +C <sub>2</sub> x X <sub>20</sub> | Cell 5 (Y <sub>20</sub> ) | | | | | 27 | 0 | 0 | 0 | 0 | 0 | 0 | C <sub>0</sub> x X <sub>21</sub> | +C <sub>1</sub> x X <sub>21</sub> | Cell 6 (Y <sub>21</sub> ) | | | | | 28 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | +C <sub>0</sub> x X <sub>22</sub> | Cell 7 (Y <sub>22</sub> ) | | | | | 29 | C <sub>15</sub> x X <sub>8</sub> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | | | | | 30 | +C <sub>14</sub> x X <sub>9</sub> | +C <sub>15</sub> x X <sub>9</sub> | 0 | 0 | 0 | 0 | 0 | 0 | - | | | | | 31 | +C <sub>13</sub> x X <sub>10</sub> | | +C <sub>15</sub> x X <sub>10</sub> | 0 | 0 | 0 | 0 | 0 | - | | | | | 32 | +C <sub>12</sub> x X <sub>11</sub> | | | +C <sub>15</sub> x X <sub>11</sub> | 0 | 0 | 0 | 0 | - | | | | | 33 | +C <sub>11</sub> x X <sub>12</sub> | | | | +C <sub>15</sub> x X <sub>12</sub> | 0 | 0 | 0 | - | | | | | 34 | +C <sub>10</sub> x X <sub>13</sub> | | | | | +C <sub>15</sub> x X <sub>12</sub> | 0 | 0 | - | | | | | 35 | +C <sub>9</sub> x X <sub>14</sub> | | | | | | +C <sub>15</sub> x X <sub>14</sub> | 0 | - | | | | | 36 | +C <sub>8</sub> x X <sub>15</sub> | | | | | | | $C_{15} \times X_{15}$ | - | | | | | 37 | +C <sub>7</sub> x X <sub>16</sub> | | | | | | | +C <sub>14</sub> x X <sub>16</sub> | - | | | | | 38 | +C <sub>6</sub> x X <sub>17</sub> | | | | | | | +C <sub>13</sub> x X <sub>17</sub> | - | | | | | 39 | +C <sub>5</sub> x X <sub>18</sub> | | | | | | | +C <sub>12</sub> x X <sub>18</sub> | - | | | | | 40 | +C <sub>4</sub> x X <sub>19</sub> | | | | | | | +C <sub>11</sub> x X <sub>19</sub> | - | | | | | 41 | +C <sub>3</sub> x X <sub>20</sub> | | | | | | | +C <sub>10</sub> x X <sub>20</sub> | - | | | | | 42 | +C <sub>2</sub> x X <sub>21</sub> | | | | | | | +C <sub>9</sub> x X <sub>21</sub> | - | | | | | 43 | +C <sub>1</sub> x X <sub>22</sub> | | | | | | | +C <sub>8</sub> x X <sub>22</sub> | | | | | | 44 | +C <sub>0</sub> x X <sub>23</sub> | | | | | | | +C <sub>7</sub> x X <sub>23</sub> | Cell 0 (Y <sub>23</sub> ) | | | | | 45 | 0 | $C_0 \times X_{23}$ | <b>*</b> | | | | | +C <sub>6</sub> x X <sub>24</sub> | Cell 1 (Y <sub>24</sub> ) | | | | | 46 | 0 | 0 | C <sub>0</sub> x X <sub>25</sub> | <b>,</b> | | | | +C <sub>5</sub> x X <sub>25</sub> | Cell 2 (Y <sub>25</sub> ) | | | | | 47<br>48 | 0<br>0 | 0 | 0 | C <sub>0</sub> x X <sub>26</sub> | | ↓ | ↓ | +C <sub>4</sub> x X <sub>26</sub> | Cell 3 (Y <sub>26</sub> ) | | | | | 40 | U | U | U | U | C <sub>0</sub> x X <sub>27</sub> | ▼ | <b>T</b> | +C <sub>3</sub> x X <sub>27</sub> | Cell 4 (Y <sub>27</sub> ) | | | | # 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 Tp = 7 + L cycles and computes eight output samples. In pass i, the sample with indices i\*8 to i\*8 +(L-1) enter the DIN0-8 inputs. The coefficients $C_0$ - $C_L$ - 1 enter the CIN0-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 x 9 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 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-two filter illustrates the technique (internal cell pipelining ignored for simplicity). Detailed timing for a 30MHz input sample rate, 15MHz 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. $$Y_N = \sum_{K=0}^{15} C_K X_{N-K}$$ FIGURE 6. HSP43891 16-TAP 30MHz FILTER TIMING USING TWO CASCADED HSP43891s TABLE 3. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE; 30MHz IN, 15MHz OUT DATA SEQUENCE INPUT . . . $X_2, X_1, X_0$ COEFFICIENT SEQUENCE INPUT . . . $C_{15}, C_0 \dots C_{13}, C_{14}, C_{15}$ HSP43891 $\dots Y_{19}, -, Y_{17}, -, Y_{15}$ | CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR | |-----|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|--------------------------| | 6 | C <sub>15</sub> x X <sub>0</sub> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | | 7 | +C <sub>14</sub> x X <sub>1</sub> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | | 8 | $+C_{13} \times X_2$ | C <sub>15</sub> x X <sub>2</sub> | 0 | 0 | 0 | 0 | 0 | 0 | - | | 9 | +C <sub>12</sub> x X <sub>3</sub> | +C <sub>14</sub> x X <sub>3</sub> | 0 | 0 | 0 | 0 | 0 | 0 | - | | 10 | +C <sub>11</sub> x X <sub>4</sub> | +C <sub>13</sub> x X <sub>4</sub> | C <sub>15</sub> x X <sub>4</sub> | 0 | 0 | 0 | 0 | 0 | - | | 11 | $+C_{10} \times X_5$ | +C <sub>12</sub> x X <sub>5</sub> | +C <sub>14</sub> x X <sub>5</sub> | 0 | 0 | 0 | 0 | 0 | - | | 12 | +C <sub>9</sub> x X <sub>6</sub> | +C <sub>11</sub> x X <sub>6</sub> | +C <sub>13</sub> x X <sub>6</sub> | C <sub>15</sub> x X <sub>6</sub> | 0 | 0 | 0 | 0 | - | | 13 | +C <sub>8</sub> x X <sub>7</sub> | +C <sub>10</sub> x X <sub>7</sub> | +C <sub>12</sub> x X <sub>7</sub> | +C <sub>14</sub> x X <sub>7</sub> | 0 | 0 | 0 | 0 | - | | 14 | $+C_7 \times X_8$ | +C <sub>9</sub> x X <sub>8</sub> | +C <sub>11</sub> x X <sub>8</sub> | +C <sub>13</sub> x X <sub>8</sub> | C <sub>15</sub> x X <sub>8</sub> | 0 | 0 | 0 | - | | 15 | +C <sub>6</sub> x X <sub>9</sub> | +C <sub>8</sub> x X <sub>9</sub> | +C <sub>10</sub> x X <sub>9</sub> | +C <sub>12</sub> x X <sub>9</sub> | +C <sub>14</sub> x X <sub>9</sub> | 0 | 0 | 0 | - | | 16 | $+C_5 \times X_{10}$ | +C <sub>7</sub> x X <sub>10</sub> | +C <sub>9</sub> x X <sub>10</sub> | +C <sub>11</sub> x X <sub>10</sub> | +C <sub>13</sub> x X <sub>10</sub> | C <sub>15</sub> x X <sub>10</sub> | 0 | 0 | - | | 17 | +C <sub>4</sub> x X <sub>11</sub> | +C <sub>6</sub> x X <sub>11</sub> | +C <sub>8</sub> x X <sub>11</sub> | +C <sub>10</sub> x X <sub>11</sub> | +C <sub>12</sub> x X <sub>11</sub> | +C <sub>14</sub> x X <sub>11</sub> | 0 | 0 | - | | 18 | $+C_3 \times X_{12}$ | +C <sub>5</sub> x X <sub>12</sub> | +C <sub>7</sub> x X <sub>12</sub> | +C <sub>9</sub> x X <sub>12</sub> | +C <sub>11</sub> x X <sub>12</sub> | +C <sub>13</sub> x X <sub>12</sub> | C <sub>15</sub> x X <sub>12</sub> | 0 | - | | 19 | $+C_2 \times X_{13}$ | +C <sub>4</sub> x X <sub>13</sub> | +C <sub>6</sub> x X <sub>13</sub> | +C <sub>8</sub> x X <sub>13</sub> | +C <sub>10</sub> x X <sub>13</sub> | +C <sub>12</sub> x X <sub>13</sub> | +C <sub>14</sub> x X <sub>13</sub> | 0 | - | | 20 | $+C_1 \times X_{14}$ | +C <sub>3</sub> x X <sub>14</sub> | +C <sub>5</sub> x X <sub>14</sub> | +C <sub>7</sub> x X <sub>14</sub> | +C <sub>9</sub> x X <sub>14</sub> | +C <sub>11</sub> x X <sub>14</sub> | +C <sub>13</sub> x X <sub>14</sub> | C <sub>15</sub> x X <sub>14</sub> | - | | 21 | $+C_0 \times X_{15}$ | +C <sub>2</sub> x X <sub>15</sub> | +C <sub>4</sub> x X <sub>15</sub> | +C <sub>6</sub> x X <sub>15</sub> | +C <sub>8</sub> x X <sub>15</sub> | +C <sub>10</sub> x X <sub>15</sub> | +C <sub>12</sub> x X <sub>15</sub> | +C <sub>14</sub> x X <sub>15</sub> | Cell0 (Y <sub>15</sub> ) | | 22 | $C_{15} \times X_{16}$ | +C <sub>1</sub> x X <sub>16</sub> | +C <sub>3</sub> x X <sub>16</sub> | +C <sub>5</sub> x X <sub>16</sub> | +C <sub>7</sub> x X <sub>16</sub> | +C <sub>9</sub> x X <sub>16</sub> | +C <sub>11</sub> x X <sub>16</sub> | +C <sub>13</sub> x X <sub>16</sub> | - | | 23 | +C <sub>14</sub> x X <sub>17</sub> | +C <sub>0</sub> x X <sub>17</sub> | +C <sub>2</sub> x X <sub>17</sub> | +C <sub>4</sub> x X <sub>17</sub> | +C <sub>6</sub> x X <sub>17</sub> | +C <sub>8</sub> x X <sub>17</sub> | +C <sub>10</sub> x X <sub>17</sub> | +C <sub>12</sub> x X <sub>17</sub> | Cell1 (Y <sub>17</sub> ) | | 24 | +C <sub>13</sub> x X <sub>18</sub> | C <sub>15</sub> x X <sub>18</sub> | +C <sub>1</sub> x X <sub>18</sub> | +C <sub>3</sub> x X <sub>18</sub> | +C <sub>5</sub> x X <sub>18</sub> | +C <sub>7</sub> x X <sub>18</sub> | +C <sub>9</sub> x X <sub>18</sub> | +C <sub>11</sub> x X <sub>18</sub> | - | | 25 | +C <sub>12</sub> x X <sub>19</sub> | +C <sub>14</sub> x X <sub>19</sub> | +C <sub>0</sub> x X <sub>19</sub> | +C <sub>2</sub> x X <sub>19</sub> | +C <sub>4</sub> x X <sub>19</sub> | +C <sub>6</sub> x X <sub>19</sub> | +C <sub>8</sub> x X <sub>19</sub> | +C <sub>10</sub> x X <sub>19</sub> | Cell2 (Y <sub>19</sub> ) | | 26 | $+C_{11} \times X_{20}$ | +C <sub>13</sub> x X <sub>20</sub> | C <sub>15</sub> x X <sub>20</sub> | +C <sub>1</sub> x X <sub>20</sub> | +C <sub>3</sub> x X <sub>20</sub> | +C <sub>5</sub> x X <sub>20</sub> | +C <sub>7</sub> x X <sub>20</sub> | +C <sub>9</sub> x X <sub>20</sub> | - | | 27 | +C <sub>10</sub> x X <sub>21</sub> | +C <sub>12</sub> x X <sub>21</sub> | +C <sub>14</sub> x X <sub>21</sub> | +C <sub>0</sub> x X <sub>21</sub> | +C <sub>2</sub> x X <sub>21</sub> | +C <sub>4</sub> x X <sub>21</sub> | +C <sub>6</sub> x X <sub>21</sub> | +C <sub>8</sub> x X <sub>21</sub> | Cell3 (Y <sub>21</sub> ) | | 28 | $+C_9 \times X_{22}$ | +C <sub>11</sub> x X <sub>22</sub> | +C <sub>13</sub> x X <sub>22</sub> | C <sub>15</sub> x X <sub>22</sub> | +C <sub>1</sub> x X <sub>22</sub> | +C <sub>3</sub> x X <sub>22</sub> | +C <sub>5</sub> x X <sub>22</sub> | +C <sub>7</sub> x X <sub>22</sub> | - | | 29 | $+C_8 \times X_{23}$ | +C <sub>10</sub> x X <sub>23</sub> | +C <sub>12</sub> x X <sub>23</sub> | +C <sub>14</sub> x X <sub>23</sub> | +C <sub>0</sub> x X <sub>23</sub> | +C <sub>2</sub> x X <sub>23</sub> | +C <sub>4</sub> x X <sub>23</sub> | +C <sub>6</sub> x X <sub>23</sub> | Cell4 (Y <sub>23</sub> ) | | 30 | $+C_7 \times X_{24}$ | +C <sub>9</sub> x X <sub>24</sub> | +C <sub>11</sub> x X <sub>24</sub> | +C <sub>13</sub> x X <sub>24</sub> | +C <sub>15</sub> x X <sub>24</sub> | +C <sub>1</sub> x X <sub>24</sub> | +C <sub>3</sub> x X <sub>24</sub> | +C <sub>5</sub> x X <sub>24</sub> | - | | 31 | $+C_6 \times X_{25}$ | +C <sub>8</sub> x X <sub>25</sub> | +C <sub>10</sub> x X <sub>25</sub> | +C <sub>12</sub> x X <sub>25</sub> | +C <sub>14</sub> x X <sub>25</sub> | +C <sub>0</sub> x X <sub>25</sub> | +C <sub>2</sub> x X <sub>25</sub> | +C <sub>4</sub> x X <sub>25</sub> | Cell5 (Y <sub>25</sub> ) | | 32 | $+C_5 \times X_{26}$ | +C <sub>7</sub> x X <sub>26</sub> | +C <sub>9</sub> x X <sub>26</sub> | +C <sub>11</sub> x X <sub>26</sub> | +C <sub>13</sub> x X <sub>26</sub> | +C <sub>15</sub> x X <sub>26</sub> | +C <sub>1</sub> x X <sub>26</sub> | +C <sub>3</sub> x X <sub>26</sub> | - | | 33 | $+C_4 \times X_{27}$ | +C <sub>6</sub> x X <sub>27</sub> | +C <sub>8</sub> x X <sub>27</sub> | +C <sub>10</sub> x X <sub>27</sub> | +C <sub>12</sub> x X <sub>27</sub> | +C <sub>14</sub> x X <sub>27</sub> | +C <sub>0</sub> x X <sub>27</sub> | +C <sub>2</sub> x X <sub>27</sub> | Cell6 (Y <sub>27</sub> ) | | 34 | $+C_3 \times X_{28}$ | +C <sub>5</sub> x X <sub>28</sub> | +C <sub>7</sub> x X <sub>28</sub> | +C <sub>9</sub> x X <sub>28</sub> | +C <sub>11</sub> x X <sub>28</sub> | +C <sub>13</sub> x X <sub>28</sub> | +C <sub>15</sub> x X <sub>28</sub> | +C <sub>1</sub> x X <sub>28</sub> | - | | 35 | $+C_2 \times X_{29}$ | +C <sub>4</sub> x X <sub>29</sub> | +C <sub>6</sub> x X <sub>29</sub> | +C <sub>8</sub> x X <sub>29</sub> | +C <sub>10</sub> x X <sub>29</sub> | +C <sub>12</sub> x X <sub>29</sub> | +C <sub>14</sub> x X <sub>29</sub> | +C <sub>0</sub> x X <sub>29</sub> | Cell7 (Y <sub>29</sub> ) | | 36 | $+C_1 \times X_{30}$ | +C <sub>3</sub> x X <sub>30</sub> | +C <sub>5</sub> x X <sub>30</sub> | +C <sub>7</sub> x X <sub>30</sub> | +C <sub>9</sub> x X <sub>30</sub> | +C <sub>11</sub> x X <sub>30</sub> | +C <sub>13</sub> x X <sub>30</sub> | C <sub>15</sub> x X <sub>30</sub> | - | | 37 | +C <sub>0</sub> x X <sub>31</sub> | +C <sub>2</sub> x X <sub>31</sub> | +C <sub>4</sub> x X <sub>31</sub> | +C <sub>6</sub> x X <sub>31</sub> | +C <sub>8</sub> x X <sub>31</sub> | +C <sub>10</sub> x X <sub>31</sub> | +C <sub>12</sub> x X <sub>31</sub> | +C <sub>14</sub> x X <sub>31</sub> | Cell8 (Y <sub>31</sub> ) | FIGURE 7. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER TIMING; 30MHz IN, 15MHz OUT #### HSP43891 # **Absolute Maximum Ratings** | Maximum Supply Voltage | |----------------------------------------------------------| | Input, Output Voltage GND -0.5V to V <sub>CC</sub> +0.5V | | Maximum Storage Temperature65°C to 150°C | | ESD | | Junction Temperature | | PLCC | | CPGA175°C | | Maximum Lead Temperature (Soldering 10s) | | Operating Conditions | | Voltage Range | | Temperature Range | #### **Thermal Information** | Thermal Resistance (Typical, Note 1) | $\theta_{JA}$ ( $^{\circ}C/W$ ) $\theta_{JC}$ | ; (°C/W) | |-------------------------------------------|-----------------------------------------------|----------| | MQFP Package | . 47 | N/A | | PLCC Package | . 37 | N/A | | CPGA Package | . 34.66 | 7.78 | | Typical Package Power Dissipation at 70°C | | | | MQFP Package | | 1.7W | | PLCC Package | | 2.2W | | CPGA Package | | 2.88W | | Gate Count | | 17763 | | (PLCC MQFP Lead Tips Only) | | | | | | | 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. #### NOTE: 1. $\theta_{\mbox{\scriptsize JA}}$ is measured with the component mounted on an evaluation PC board in free air. #### **DC Electrical Specifications** | PARAMETER | | SYMBOL | TEST CONDITIONS | MIN | MAX | UNITS | |------------------------------------------|------|------------------------------------------------------------------|---------------------------------------------------------|-----|-----|-------| | Power Supply Current | | ICCOP | V <sub>CC</sub> = Max, CLK Frequency 20MHz (Notes 2, 4) | - | 140 | mA | | Standby Power Supply Cui | rent | ICCSB | V <sub>CC</sub> = Max (Note 4) | - | 500 | μΑ | | Input Leakage Current | | l <sub>l</sub> | V <sub>CC</sub> = Max, Input = 0V or V <sub>CC</sub> | -10 | 10 | μΑ | | Output Leakage Current | | Io | V <sub>CC</sub> = Max, Input = 0V or V <sub>CC</sub> | -10 | 10 | μΑ | | Logical One Input Voltage | | V <sub>IH</sub> | V <sub>CC</sub> = Max | 2.0 | - | V | | Logical Zero Input Voltage | | V <sub>IL</sub> | V <sub>CC</sub> = Min | - | 0.8 | V | | Logical One Output Voltage | | V <sub>OH</sub> | $I_{OH}$ = -400 $\mu$ A, $V_{CC}$ = Min | 2.6 | - | V | | Logical Zero Output Voltag | е | V <sub>OL</sub> | I <sub>OL</sub> = 2mA, V <sub>CC</sub> = Min | - | 0.4 | V | | Clock Input High | | V <sub>IHC</sub> | V <sub>CC</sub> = Max | 3.0 | - | V | | Clock Input Low | | V <sub>ILC</sub> | V <sub>CC</sub> = Min | - | 0.8 | V | | Input Capacitance | PLCC | C <sub>IN</sub> | CLK Frequency 1MHz | - | 10 | pF | | | CPGA | All measurements referenced to GND, T <sub>A</sub> = 25 (Note 3) | | - | 15 | pF | | Output Capacitance PLCC C <sub>OUT</sub> | | | - | 10 | pF | | | | CPGA | | | - | 15 | pF | #### NOTES: - 2. Operating supply current is proportional to frequency. Typical rating is 7mA/MHz. - 3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes. - 4. Output load per test load circuit and $C_L$ = 40pF. AC Electrical Specifications $V_{CC}$ = 5V, ±5%, $T_A$ = 0°C to 70°C | | | TEST | -20 (20MHz) | | -25 (25.6MHz) | | -30 (30MHz) | | | |---------------------------------|------------------|------------|-------------|-----|---------------|-----|-------------|-----|-------| | PARAMETER | SYMBOL | CONDITIONS | MIN | MAX | MIN | MAX | MIN | MAX | UNITS | | Clock Period | t <sub>CP</sub> | | 50 | - | 39 | - | 33 | - | ns | | Clock Low | t <sub>CL</sub> | | 20 | - | 16 | - | 13 | - | ns | | Clock High | t <sub>CH</sub> | | 20 | - | 16 | - | 13 | - | ns | | Input Setup | t <sub>IS</sub> | | 16 | - | 14 | - | 13 | - | ns | | Input Hold | t <sub>IH</sub> | | 0 | - | 0 | - | 0 | - | ns | | CLK to Coefficient Output Delay | t <sub>ODC</sub> | | - | 24 | - | 20 | - | 18 | ns | | Output Enable Delay | t <sub>OED</sub> | | - | 20 | - | 15 | - | 15 | ns | | Output Disable Delay | t <sub>ODD</sub> | Note 5 | - | 20 | - | 15 | - | 15 | ns | | CLK to SUM Output Delay | t <sub>ODS</sub> | | - | 27 | - | 25 | - | 21 | ns | | Output Rise | t <sub>OR</sub> | Note 5 | - | 6 | - | 6 | - | 6 | ns | | Output Fall | tOF | Note 5 | - | 6 | - | 6 | - | 6 | ns | #### NOTE: # **Test Load Circuit** NOTE: Switch $S_1$ Open for $I_{\mbox{\scriptsize CCSB}}$ and $I_{\mbox{\scriptsize CCOP}}$ Tests. <sup>5.</sup> Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes. #### Waveforms NOTE: Input includes:DIN0-7, CIN0-7, DIENB, CIENB, ERASE, RESET, DCM0-1, ADR0-1, TCS, TCCI, SHADD FIGURE 9. INPUT SETUP AND HOLD FIGURE 8. CLOCK AC PARAMETERS FIGURE 10. SUM0-25, COUT0-8, OUTPUT DELAYS FIGURE 11. RISE AND FALL TIMES FIGURE 12. OUTPUT ENABLE, DISABLE TIMING NOTE: AC Testing: Inputs are driven at 3.0V for a Logic "1" and 0.0V for a Logic "0". Input and output timing measurements are made at 1.5V for both a Logic "1" and "0". CLK is driven at 4.0V and 0V and measured at 2.0V. FIGURE 13. AC TESTING INPUT, OUTPUT WAVEFORM #### All Intersil semiconductor products are manufactured, assembled and tested under ISO9000 quality systems certification. Intersil semiconductor products are sold by description only. Intersil Corporation reserves the right to make changes in circuit design and/or specifications at any time without notice. Accordingly, the reader is cautioned to verify that data sheets are current before placing orders. Information furnished by Intersil is believed to be accurate and reliable. However, no responsibility is assumed by Intersil or its subsidiaries for its use; nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Intersil or its subsidiaries. For information regarding Intersil Corporation and its products, see web site http://www.intersil.com # Sales Office Headquarters **NORTH AMERICA** Intersil Corporation P. O. Box 883, Mail Stop 53-204 Melbourne, FL 32902 TEL: (407) 724-7000 TEL: (407) 724-7000 FAX: (407) 724-7240 #### **EUROPE** Intersil SA Mercure Center 100, Rue de la Fusee 1130 Brussels, Belgium TEL: (32) 2.724.2111 FAX: (32) 2.724.22.05 #### ASIA Intersil (Taiwan) Ltd. 7F-6, No. 101 Fu Hsing North Road Taipei, Taiwan Republic of China TEL: (886) 2 2716 9310 FAX: (886) 2 2715 3029