WO1995017708A2 - Calculation of a scalar product in a direct-type fir filter - Google Patents

Calculation of a scalar product in a direct-type fir filter Download PDF

Info

Publication number
WO1995017708A2
WO1995017708A2 PCT/FI1994/000568 FI9400568W WO9517708A2 WO 1995017708 A2 WO1995017708 A2 WO 1995017708A2 FI 9400568 W FI9400568 W FI 9400568W WO 9517708 A2 WO9517708 A2 WO 9517708A2
Authority
WO
WIPO (PCT)
Prior art keywords
bit
elements
serial
adder
subtractor
Prior art date
Application number
PCT/FI1994/000568
Other languages
French (fr)
Other versions
WO1995017708A3 (en
Inventor
Eero Pajarre
Ville Eerola
Tapio SARAMÄKI
Tapani Ritoniemi
Timo Husu
Seppo Ingalsuo
Original Assignee
Eero Pajarre
Ville Eerola
Saramaeki Tapio
Tapani Ritoniemi
Timo Husu
Seppo Ingalsuo
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Eero Pajarre, Ville Eerola, Saramaeki Tapio, Tapani Ritoniemi, Timo Husu, Seppo Ingalsuo filed Critical Eero Pajarre
Priority to US08/505,257 priority Critical patent/US6131105A/en
Priority to DE69421073T priority patent/DE69421073T2/en
Priority to JP7517215A priority patent/JPH08506953A/en
Priority to EP95903364A priority patent/EP0685127B1/en
Priority to KR1019950703435A priority patent/KR960701409A/en
Publication of WO1995017708A2 publication Critical patent/WO1995017708A2/en
Publication of WO1995017708A3 publication Critical patent/WO1995017708A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03HIMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
    • H03H17/00Networks using digital techniques
    • H03H17/02Frequency selective networks
    • H03H17/06Non-recursive filters

Definitions

  • the present invention relates to a digital direct- type FIR filter, and in particular to calculation of a scalar product in a direct-type FIR filter.
  • a digital filter is a software or a specially designed electronic circuit processing discrete digital signal samples to perform a desired transfer function operation on said signal.
  • the Z transfer function of a digital, i.e. discrete time, FIR (Finite Impulse Response) filter has the generic form
  • H(z) is the transfer function of the filter
  • Y(z) and X(z) represent the output and input of the filter respectively
  • a ⁇ represent constant coefficients, i.e. tap coefficients
  • z " represents a delay of i samples.
  • the properties of a FIR filter are solely dependent on the tap coefficients a x , and thus determination of these coeffici ⁇ ents is required in order to obtain the desired character ⁇ istics for the filter. There are several methods for determining the coefficients.
  • the non-recursive discrete time filter in accordance with equation (1) is normally represented as a block diagram as shown in Figures 1 and 2.
  • Figure 1 illustrates a direct-type FIR (Finite Impulse Response) filter and
  • Figure 2 a transposed FIR filter.
  • the filtering function in accordance with equation (1) can be realized by both types of discrete time filter, but the present invention relates to a direct-type FIR filter according to Figure 1.
  • the discrete time filter is illustrated as a block dia ⁇ gram wherein square blocks 1 perform delaying of the information by one sample z "1 , triangular blocks 2 repres ⁇ ent multiplication operations, and circles 3 represent adders.
  • the characteristics of the filter are dependent on the values of the tap coefficients a ⁇ .
  • Prior art direct-type FIR filters exist in which a dis ⁇ crete multiplier unit for each tap coefficient is em ⁇ ployed.
  • the object of the present invention is a direct- type digital FIR filter that can be embodied as an integ ⁇ rated circuit with several coefficients so as to occupy substantially less chip area in integrated circuit con- figuration than the filters implemented by the prior art techniques.
  • Another object of the present invention is a digi ⁇ tal filter suitable for comparatively high clock fre ⁇ quencies.
  • a further object of the present invention is a digital filter enabling realization of arbitrary coef ⁇ ficients automatically.
  • a method for calculating a scalar product in a direct-type digital FIR filter comprising delaying successive words of a digital input signal in a delay line having delays of the duration of one word, and calculating the scalar product between the variously delayed words derived from the delay line and the corresponding coefficients, the method being characterized in that the calcula ⁇ tion step comprises combining the bits of words at the input and out- puts of the delay line bit by bit in a network of bit- serial subtractor and/or adder elements wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two, and summing together the results to yield said scalar product.
  • Another aspect of the invention is a direct-type digital FIR filter, comprising a delay line having an input for receiving digital words in serial form, a plurality of one-word delays and an output after each delay; calculation means for calculating the scalar prod- uct between the words at the input and each output of the delay line and the corresponding coefficients; an output to which the calculated scalar product is applied, the filter being characterized in that said calculation means comprise a plurality of bit-serial subtractor and/or adder elements for combining bits of words at the input and each output of the delay line, said bit-serial subtractor and/ or adder elements forming a network wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, means for multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two and summing together the results to yield said scalar product.
  • One aspect of the invention is a method for design ⁇ ing a direct-type digital filter, comprising a step of determining the coefficients required in the filter.
  • This method is characterized in accordance with the invention by further steps of designing a network of bit-serial subtractor and/or adder elements for the filter, wherein the number of said bit-serial elements is minimized taking into account per- formance criteria of the filter, so that a maximum number of said bit-serial elements are involved in the multi ⁇ plication operation of more than one different coeffici ⁇ ents, designing an output register performing multiplica- tion by a power of two and summing together the results from said network, said register comprising one-bit delay elements and bit-serial adder and subtractor elements.
  • the scalar product is calculated by combining values derived from the delay line in bit-serial adder and/or subtractor elements, so that at least some of the adder and/or subtractor elements are used to provide the mantissa of more than one coefficient.
  • the "partial sum” or “partial difference” outputted by a specific adder or subtractor element can be used on the next level of the adder and/or subtractor ele ⁇ ment network to produce the mantissas of several coeffici ⁇ ents simultaneously.
  • the combined use of adder and subtractor elements in producing the coefficients enables the number of calculation elements (+/- operators) to be minimized.
  • the products given by the network of calculation elements are multiplied by the exponent of the respective coef ⁇ ficient and summed together to produce the final scalar product.
  • the arrangement of the invention affords good round-off and truncation behaviour.
  • the scalar product is rounded off or truncated only once, and thus the error in the scalar product is, on an average, only 1/2 least sig ⁇ nificant bits.
  • Multiplication by a power of two and sum ⁇ mation are preferably performed on all coefficients in the same output register, which is comprised of one-bit delays and bit-serial adder and subtractor elements. Thus the number of necessary delays can be optimized as compared with a case where each coefficient has dedicated calcula ⁇ tion elements, delay elements, for multiplication by a power of two.
  • the network of bit- serial adder and subtractor elements can be optimized by finding the sum and/or difference of powers of two for the coefficients required, so as to considerably diminish the requisite number of calculation elements in comparison with the prior art solutions.
  • the requi ⁇ site number of series-connected elements is characteris ⁇ tically diminished.
  • an- other advantage of the invention is a low number of logic levels, and thus the maximum operating frequency is very high.
  • the silicon area occupation required is less than half the area required by the digital filter shown in Fig- ure 3 which includes a multiplier and RAM and ROM memories.
  • Figure 1 is a block diagram of a direct-type digi ⁇ tal FIR filter
  • Figure 2 is a block diagram of a transposed digital
  • Figure 3 is a block diagram of a prior art digital filter implemented by a fast multiplier and memories.
  • Figure 4 is a block diagram of a digital filter of the invention with five coefficients.
  • Figure 5 is a block diagram of an embodiment of the digital filter of Figure 4, and
  • Figure 6 is a block diagram of a bit-serial adder element.
  • the filter comprises a delay line having four delay blocks 50A, 50B, 50C and 50D, each having a length of one word (z "1 ) .
  • Each delay block is made up of N one-bit delay elements 49, as in delay block 50D in Figure 5.
  • N is the word width of the filter.
  • the number sequence X obtained at the input IN is supplied to delay line 50A-50D in bit- serial form, each value as N successive bits, the least significant bit LSB occurring first.
  • the words are clocked through the delay line in such a way that each word is shifted one bit at each clock cycle.
  • the delay line 50A-50D (the input included) provides an output of five variously delayed values x 0 , x 1 , x 2 , x 3 and x 4 in bit-serial form.
  • the values thus obtained should be multiplied by the corresponding tap coefficients a 0 , a x , a 2 , a 3 and a 4 , whereafter the products obtained are summed together to give the desired scalar product, as in the schematic block diagram of a direct-type FIR filter of Figure 1.
  • a network of combining elements 51, 52, 53, 54, 55 and 56 is coupled to the outputs of the delay line for multiplication of the words x0-x4 by tap coefficients a 1 -a 4 by combining the one-bit outputs of the delay line.
  • the network of combining elements comprises bit-serial adder and subtractor elements 51, 52, 53, 54, 55 and 56 employ ⁇ ing bit-serial arithmetic on several levels. In accordance with the basic concept of the invention, it has been sought to minimize the number of calculation elements taking into account certain performance criteria for the filter, so that the same calculation elements are employed to produce more than one different tap coefficients.
  • five coefficients are formed by employing only six bit-serial (one-bit) arith- etic elements.
  • the inputs of the adder ele ⁇ ment 53 are provided by the outputs x 2 and x 3 of the delay line.
  • the output value x 2 + x 3 of the adder element 53 provides an input for adder elements 52 and 54 on the next network level.
  • the calculation elements 51, 52, 54, 55 and 56 respectively provide five outputs, which are then multiplied by the requisite power of two in multiplier units 57A, 57B, 57C, 57D and 57E.
  • the outputs of multiplier units 57A-57E are summed together in an adder 58 to obtain the desired scalar product
  • multiplier units 57A-57E have in one embodiment of the invention been configured by using one- bit delay elements, one delay element for each power of two.
  • multiplier unit 57A has nine one-bit delays and multiplier unit 57D three one-bit delays.
  • the embodiment of Figure 4 requires a total of 23 one-bit delay elements to implement the multiplier units 57A-57D.
  • Figure 5 shows the preferred embodiment of the invention, in which elements and functions similar to those in Figure 4 are denoted by the same reference numerals and symbols.
  • the delay line 50A-50D and the network of calculation elements 51-56 are identical with those of the embodiment of Figure 4.
  • the multiplier units 57A-57D and adder 58 of Figure 4 are replaced by a common output register in Figure 5.
  • the output register comprises a series connection of the following elements in the given order: three one-bit delay elements 49A, 49B and 49C, an adder 45, a one-bit delay element 49D, an adder 46, two one-bit delay elements 49E and 49F, a subtractor 47, three one-bit delay elements 49G, 49H and 49K, and an adder 48.
  • the output of element 51 is coupled to the input of delay element 49A
  • the output of element 52 is coupled to adder 45 together with the output of delay element 49C
  • the output of element 54 is coupled to adder 46 together with the output of delay element 49D
  • the output of element 55 is coupled to subtractor 47 together with the output of delay element 49F
  • the output of element 56 is coupled to adder 48 together with the output of delay element 49K.
  • the output of adder 48 provides the output OUT for the filter.
  • the calculation elements 45, 46, 47 and 48 are bit-serial calculation elements.
  • the embodiment of Figure 5 employs common delays for different coefficients, thus enabling further reduction in the number of elements required for the filter.
  • the output register comprises nine delay elements and four calcula- tion elements, while the corresponding operation in the embodiment of Figure 4 requires 23 delay elements and one calculation element.
  • All calculation elements 51-56, 45-48 and delay elements 49A-49K of the output register are reset to zero at the start of the calculation.
  • the advantages of the filter in accordance with the invention include the fact that all these elements can be reset simultaneously, and the resetting can be performed with a single control signal. Thereafter a new value xO is clocked to the delay line 50A-50D, and thus the values x x -x 4 clocked to the delay line during the previous calculation cycles are shifted one delay block forward.
  • bit-serial values x 0 -x 4 derived from the delay lines are applied to the bit- serial calculation network 51-56, the outputs of which yield bit-serial values x 0 -x 2 , x 1 +x 2 +x 3 , x 0 +x 2 +x 3 +x 4 , x 0 +x 4 and x 3 -x 4 .
  • the values thus obtained from the calculation net ⁇ work 51-56 are applied in bit-serial form to the output register that combines them, simultaneously delaying them for various periods of time.
  • delay- ing a bit-serial value for one bit corresponds to multi ⁇ plying the value by two.
  • the output register delays the input values by 9, 6, 5, 3 and 0 bits, which corresponds to multiplying the values by 512, 64, 32, 8 and 1 respectively.
  • the value of the output OUT of the output register gives the value
  • Figure 6 shows a block diagram of a bit-serial adder element.
  • the adder element comprises a one-bit delay block 61, which in this exemplary case is implemented by a D flip-flop, and an adder 62 adding up two data bits and outputting a sum and a carry bit c out .
  • All signals shown in Figure 6 are one-bit signals, i.e. each of them can be implemented by a single signal line.
  • the adder element shown in Figure 6 operates in the following way. The values to be summed together are applied to the adder 62 in serial form, the least significant bit (LSB) being the first.
  • LSB least significant bit
  • the adding up of two bits a and b and a carry bit c ln gives as a result one sum bit sum and a carry bit c out which is stored in the delay block 61 for summing together the next bits.
  • the delay block 61 is reset between the addition of two successive N-bit values by way of the reset line.
  • bit-serial subtractor element can be embodied similarly. The only difference is that instead of an adder
  • the delay block 61 is set to the value 1 between the subtraction of two successive N-bit values.

Abstract

The invention relates to a direct-type FIR filter, a method for calculating a scalar product in a FIR filter, and a method for designing a direct-type FIR filter. Successive words of a digital input signal are delayed in a delay line having delays (50A-50D) of the duration of one word, and the scalar product between the variously delayed words derived from the delay line and the corresponding constant coefficients is calculated. In accordance with the invention, calculation of the scalar product comprises: (a) combining the bits of words at the input (X0) and outputs (X1-X4) of the delay line bit by bit in a network of bit-serial subtractor and/or adder elements (51-56) wherein at least one of the bit-serial elements is involved in the multiplication operation of at least two different coefficients; and (b) multiplying (49A-K) the multiplication results from the network by powers of two, and summing together (45-48) the results to yield the scalar product.

Description

Calculation of a scalar product in a direct-type FIR filter
Field of the Invention
The present invention relates to a digital direct- type FIR filter, and in particular to calculation of a scalar product in a direct-type FIR filter.
Background of the Invention
A digital filter is a software or a specially designed electronic circuit processing discrete digital signal samples to perform a desired transfer function operation on said signal. The Z transfer function of a digital, i.e. discrete time, FIR (Finite Impulse Response) filter has the generic form
Figure imgf000003_0001
where H(z) is the transfer function of the filter, Y(z) and X(z) represent the output and input of the filter respectively, a± represent constant coefficients, i.e. tap coefficients, and z" represents a delay of i samples. The properties of a FIR filter are solely dependent on the tap coefficients ax, and thus determination of these coeffici¬ ents is required in order to obtain the desired character¬ istics for the filter. There are several methods for determining the coefficients. The non-recursive discrete time filter in accordance with equation (1) is normally represented as a block diagram as shown in Figures 1 and 2. Figure 1 illustrates a direct-type FIR (Finite Impulse Response) filter and Figure 2 a transposed FIR filter. The filtering function in accordance with equation (1) can be realized by both types of discrete time filter, but the present invention relates to a direct-type FIR filter according to Figure 1. As is apparent from Figures 1 and 2, the discrete time filter is illustrated as a block dia¬ gram wherein square blocks 1 perform delaying of the information by one sample z"1, triangular blocks 2 repres¬ ent multiplication operations, and circles 3 represent adders. As stated previously, the characteristics of the filter are dependent on the values of the tap coefficients a±. Prior art direct-type FIR filters exist in which a dis¬ crete multiplier unit for each tap coefficient is em¬ ployed. The drawback of this approach is the large number of multiplier units required, which occupy a considerable area on a semiconductor chip when embodied as an integ¬ rated circuit and are therefore costly. A prior art approach is known in which the tap coefficients are simple sums of powers of two, i.e. the coefficients are limited to the form 2"a+2"+2"c. Such an approach is attended by the drawback of limitations in the possible coefficients to be realized. These limitations can substantially complicate the realization of the desired signal processing function H(z). Still another prior art solution entails the use of a fast multiplier and memory for realizing the filter. Such a solution is illustrated in Figure 3, wherein the necessary delays z-1 are generated by buffering the values of the input signal X(z) into a RAM memory 41 prior to in- putting them to a multiplier 42, in which they are multi¬ plied by coefficients ai derived from a ROM memory. There¬ after the multiplication results are supplied to an adder 44 wherein they are summed with the filter output Y(z). The drawback of such a solution is the chip area occupied by the fast multiplier unit 42. Further drawbacks include the high power consumption of the multiplier unit 42 and, in certain applications, the electromagnetic interference produced thereby in other circuitry. Furthermore, on account of the limited speed of the multiplier unit, only a limited number of coefficients aA can be realized with one multiplier unit. Complex structures require several multiplier units and a complex control logic.
Disclosure of the Invention
The object of the present invention is a direct- type digital FIR filter that can be embodied as an integ¬ rated circuit with several coefficients so as to occupy substantially less chip area in integrated circuit con- figuration than the filters implemented by the prior art techniques.
Another object of the present invention is a digi¬ tal filter suitable for comparatively high clock fre¬ quencies. A further object of the present invention is a digital filter enabling realization of arbitrary coef¬ ficients automatically.
These and other objects and advantages of the invention are achieved with a method for calculating a scalar product in a direct-type digital FIR filter, the method comprising delaying successive words of a digital input signal in a delay line having delays of the duration of one word, and calculating the scalar product between the variously delayed words derived from the delay line and the corresponding coefficients, the method being characterized in that the calcula¬ tion step comprises combining the bits of words at the input and out- puts of the delay line bit by bit in a network of bit- serial subtractor and/or adder elements wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two, and summing together the results to yield said scalar product.
Another aspect of the invention is a direct-type digital FIR filter, comprising a delay line having an input for receiving digital words in serial form, a plurality of one-word delays and an output after each delay; calculation means for calculating the scalar prod- uct between the words at the input and each output of the delay line and the corresponding coefficients; an output to which the calculated scalar product is applied, the filter being characterized in that said calculation means comprise a plurality of bit-serial subtractor and/or adder elements for combining bits of words at the input and each output of the delay line, said bit-serial subtractor and/ or adder elements forming a network wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, means for multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two and summing together the results to yield said scalar product.
One aspect of the invention is a method for design¬ ing a direct-type digital filter, comprising a step of determining the coefficients required in the filter. This method is characterized in accordance with the invention by further steps of designing a network of bit-serial subtractor and/or adder elements for the filter, wherein the number of said bit-serial elements is minimized taking into account per- formance criteria of the filter, so that a maximum number of said bit-serial elements are involved in the multi¬ plication operation of more than one different coeffici¬ ents, designing an output register performing multiplica- tion by a power of two and summing together the results from said network, said register comprising one-bit delay elements and bit-serial adder and subtractor elements.
In the present invention, the scalar product is calculated by combining values derived from the delay line in bit-serial adder and/or subtractor elements, so that at least some of the adder and/or subtractor elements are used to provide the mantissa of more than one coefficient. In other words, the "partial sum" or "partial difference" outputted by a specific adder or subtractor element can be used on the next level of the adder and/or subtractor ele¬ ment network to produce the mantissas of several coeffici¬ ents simultaneously. Furthermore, in the arrangement of the invention the combined use of adder and subtractor elements in producing the coefficients enables the number of calculation elements (+/- operators) to be minimized. The products given by the network of calculation elements are multiplied by the exponent of the respective coef¬ ficient and summed together to produce the final scalar product. The arrangement of the invention affords good round-off and truncation behaviour. The scalar product is rounded off or truncated only once, and thus the error in the scalar product is, on an average, only 1/2 least sig¬ nificant bits. Multiplication by a power of two and sum¬ mation are preferably performed on all coefficients in the same output register, which is comprised of one-bit delays and bit-serial adder and subtractor elements. Thus the number of necessary delays can be optimized as compared with a case where each coefficient has dedicated calcula¬ tion elements, delay elements, for multiplication by a power of two.
By means of the invention, the network of bit- serial adder and subtractor elements can be optimized by finding the sum and/or difference of powers of two for the coefficients required, so as to considerably diminish the requisite number of calculation elements in comparison with the prior art solutions. At the same time, the requi¬ site number of series-connected elements is characteris¬ tically diminished. With the construction of the inven¬ tion, arbitrary coefficients can be realized. Still an- other advantage of the invention is a low number of logic levels, and thus the maximum operating frequency is very high. When the invention is realized as an integrated cir¬ cuit, the silicon area occupation required is less than half the area required by the digital filter shown in Fig- ure 3 which includes a multiplier and RAM and ROM memories.
Brief Description of the Drawings
In the following the invention will be set forth by means of preferred embodiments with reference to the accompanying drawing, wherein
Figure 1 is a block diagram of a direct-type digi¬ tal FIR filter, Figure 2 is a block diagram of a transposed digital
FIR filter.
Figure 3 is a block diagram of a prior art digital filter implemented by a fast multiplier and memories.
Figure 4 is a block diagram of a digital filter of the invention with five coefficients. Figure 5 is a block diagram of an embodiment of the digital filter of Figure 4, and
Figure 6 is a block diagram of a bit-serial adder element.
Preferred embodiments of the Invention
Reference will now be made to Figure 4, showing a five-coefficient direct-type digital FIR filter imple- mented in accordance with the invention. After the input IN, the filter comprises a delay line having four delay blocks 50A, 50B, 50C and 50D, each having a length of one word (z"1) . Each delay block is made up of N one-bit delay elements 49, as in delay block 50D in Figure 5. N is the word width of the filter. The number sequence X obtained at the input IN is supplied to delay line 50A-50D in bit- serial form, each value as N successive bits, the least significant bit LSB occurring first. The words are clocked through the delay line in such a way that each word is shifted one bit at each clock cycle. In other words, during N successive clock cycles each bit of word appears in turn at the one-bit output of the respective delay block. Thus the delay line 50A-50D (the input included) provides an output of five variously delayed values x0, x1, x2, x3 and x4 in bit-serial form. The values thus obtained should be multiplied by the corresponding tap coefficients a0, ax, a2, a3 and a4, whereafter the products obtained are summed together to give the desired scalar product, as in the schematic block diagram of a direct-type FIR filter of Figure 1.
A network of combining elements 51, 52, 53, 54, 55 and 56 is coupled to the outputs of the delay line for multiplication of the words x0-x4 by tap coefficients a1-a4 by combining the one-bit outputs of the delay line. The network of combining elements comprises bit-serial adder and subtractor elements 51, 52, 53, 54, 55 and 56 employ¬ ing bit-serial arithmetic on several levels. In accordance with the basic concept of the invention, it has been sought to minimize the number of calculation elements taking into account certain performance criteria for the filter, so that the same calculation elements are employed to produce more than one different tap coefficients. In the exemplary case of Figure 4, five coefficients are formed by employing only six bit-serial (one-bit) arith- etic elements. For instance, the inputs of the adder ele¬ ment 53 are provided by the outputs x2 and x3 of the delay line. On the other hand, the output value x2 + x3 of the adder element 53 provides an input for adder elements 52 and 54 on the next network level. The calculation elements 51, 52, 54, 55 and 56 respectively provide five outputs, which are then multiplied by the requisite power of two in multiplier units 57A, 57B, 57C, 57D and 57E. The outputs of multiplier units 57A-57E are summed together in an adder 58 to obtain the desired scalar product
y = 1∑=0 "A (2)
Delaying of a bit-serial value for the duration of one bit corresponds to multiplying the value by two. Therefore, the multiplier units 57A-57E have in one embodiment of the invention been configured by using one- bit delay elements, one delay element for each power of two. Thus for example multiplier unit 57A has nine one-bit delays and multiplier unit 57D three one-bit delays. Hence the embodiment of Figure 4 requires a total of 23 one-bit delay elements to implement the multiplier units 57A-57D.
Figure 5 shows the preferred embodiment of the invention, in which elements and functions similar to those in Figure 4 are denoted by the same reference numerals and symbols. In the embodiment of Figure 5, the delay line 50A-50D and the network of calculation elements 51-56 are identical with those of the embodiment of Figure 4. On the other hand, the multiplier units 57A-57D and adder 58 of Figure 4 are replaced by a common output register in Figure 5. The output register comprises a series connection of the following elements in the given order: three one-bit delay elements 49A, 49B and 49C, an adder 45, a one-bit delay element 49D, an adder 46, two one-bit delay elements 49E and 49F, a subtractor 47, three one-bit delay elements 49G, 49H and 49K, and an adder 48. In the network of calculation elements 51-56, the output of element 51 is coupled to the input of delay element 49A, the output of element 52 is coupled to adder 45 together with the output of delay element 49C, the output of element 54 is coupled to adder 46 together with the output of delay element 49D, the output of element 55 is coupled to subtractor 47 together with the output of delay element 49F, and the output of element 56 is coupled to adder 48 together with the output of delay element 49K. The output of adder 48 provides the output OUT for the filter. The calculation elements 45, 46, 47 and 48 are bit-serial calculation elements. The embodiment of Figure 5 employs common delays for different coefficients, thus enabling further reduction in the number of elements required for the filter. In the exemplary case, the output register comprises nine delay elements and four calcula- tion elements, while the corresponding operation in the embodiment of Figure 4 requires 23 delay elements and one calculation element.
The operation of the filter of the invention will be described hereinbelow with reference to the embodiment of Figure 5. All calculation elements 51-56, 45-48 and delay elements 49A-49K of the output register are reset to zero at the start of the calculation. The advantages of the filter in accordance with the invention include the fact that all these elements can be reset simultaneously, and the resetting can be performed with a single control signal. Thereafter a new value xO is clocked to the delay line 50A-50D, and thus the values xx-x4 clocked to the delay line during the previous calculation cycles are shifted one delay block forward. During the next N clock cycles, the values x0, xx, x2, x3 and x4 with mutually different delays are thus derived bit by bit in bit-serial form as outputs from the delay line. The bit-serial values x0-x4 derived from the delay lines are applied to the bit- serial calculation network 51-56, the outputs of which yield bit-serial values x0-x2, x1+x2+x3, x0+x2+x3+x4, x0+x4 and x3-x4. The values thus obtained from the calculation net¬ work 51-56 are applied in bit-serial form to the output register that combines them, simultaneously delaying them for various periods of time. As stated previously, delay- ing a bit-serial value for one bit corresponds to multi¬ plying the value by two. Hence in the embodiment of Figure 5 the output register delays the input values by 9, 6, 5, 3 and 0 bits, which corresponds to multiplying the values by 512, 64, 32, 8 and 1 respectively. Thus the value of the output OUT of the output register gives the value
512(x0-x2)+64(x1+x2+x3)+32(x0+x2+x3+x4)-8(x0+x4)+(x3-x4)
= 536x0+64x1-416x2+97x3+23x4=r (3)
After the entire word to be loaded in has been clocked bit by bit to the delay line 50A-50D and the cal¬ culation network 51-56 during N clock cycles, there are still numbers significant for the calculation in the out¬ put register and in the values stored in the calculation network 51-56. In order that the final product may be outputted from the filter, clocking of the delay line 50A- 50D and the calculation network 51-56 is continued for further ten clock cycles, whereupon the entire product is derived. When calculation is performed in accordance with the foregoing, the word width of the product in the filter increases considerably. If it is not desired to take advantage of this, n first bits of the product clocked from the adder 48 to the output OUT are omitted. This cor- responds to dividing the product by 2n. If for example in the embodiment of Figure 5 ten first output bits are omitted at the output OUT, the filter has the calculated function
512(x0-x2)+64(x1+x2+x3)+32(x0+x2+x3+x4)-8(x0-l-x4)-l-(X3-x4)
1024 = | 0.5234375x0+0.0625x1-0.40625x2+0.0947265625x3+0.0224609375x4 |
( 4 )
Figure 6 shows a block diagram of a bit-serial adder element. The adder element comprises a one-bit delay block 61, which in this exemplary case is implemented by a D flip-flop, and an adder 62 adding up two data bits and outputting a sum and a carry bit cout. All signals shown in Figure 6 are one-bit signals, i.e. each of them can be implemented by a single signal line. The adder element shown in Figure 6 operates in the following way. The values to be summed together are applied to the adder 62 in serial form, the least significant bit (LSB) being the first. The adding up of two bits a and b and a carry bit cln gives as a result one sum bit sum and a carry bit cout which is stored in the delay block 61 for summing together the next bits. The delay block 61 is reset between the addition of two successive N-bit values by way of the reset line.
The bit-serial subtractor element can be embodied similarly. The only difference is that instead of an adder
62, a subtractor is employed. Furthermore, the delay block 61 is set to the value 1 between the subtraction of two successive N-bit values.
The figures and the description relating to them are only intended to illustrate the present invention. In their details, the methods and filter of the invention can vary within the purview of the accompanying claims.

Claims

Claims :
1. A method for calculating a scalar product in a direct-type digital FIR filter, the method comprising delaying successive words of a digital input signal in a delay line having delays of the duration of one word, and calculating the scalar product between the variously delayed words derived from the delay line and the corresponding coefficients, c h a r a c t e r i z e d in that the calculation step comprises combining the bits of words at the input and out¬ puts of the delay line bit by bit in a network of bit- serial subtractor and/or adder elements wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two, and summing together the results to yield said scalar product.
2. A direct-type digital FIR filter, comprising a delay line having an input (X0) for receiving digital words in serial form, a plurality of one-word delays (50A-50D) and an output (XI, X2, X3, X4) after each delay; calculation means for calculating the scalar product between the words at the input (X0) and each output (XI, X2, X3, X4) of the delay line and the cor- responding coefficients; an output (OUT) to which the calculated scalar product is applied, c h a r a c t e r i z e d in that said calculation means comprise a plurality of bit-serial subtractor and/or adder elements (51-56) for combining bits of words at the input (X0) and each output (XI, X2, X3, X4) of the delay line, said bit-serial subtractor and/or adder elements forming a network wherein at least one of said bit-serial subtractor and/or adder elements is involved in the multiplication operation of at least two different coefficients, means (57A-D, 58; 49A-49K, 45-47) for multiplying the multiplication results from the network of bit-serial subtractor and/or adder elements by powers of two and summing together the results to yield said scalar product.
3. A FIR filter as claimed in claim 2, c h a r ¬ a c t e r i z e d in that said means for multiplying by powers of two comprise an output register comprised of one-bit delay elements (49A-K) and bit-serial adder and subtractor elements (45-48), one one-bit delay element for each power of two and one bit-serial adder or subtractor element for each coefficient.
4. A FIR filter as claimed in claim 2, c h a r ¬ a c t e r i z e d in that each delay (50A-D) in the delay line comprises n one-bit delay elements (49), wherein n is the word width in bits.
5. A method for designing a direct-type digital filter, comprising a step of determining the coefficients required in the filter, c h a r a c t e r i z e d by further steps of designing a network of bit-serial subtractor and/or adder elements for the filter, wherein the number of said bit-serial elements is minimized taking into account per- formance criteria of the filter, so that a maximum number of said bit-serial elements are involved in the multi¬ plication operation of more than one different coefficients, designing an output register performing multiplica¬ tion by a power of two and summing together the results from said network, said register comprising one-bit delay elements and bit-serial adder and subtractor elements.
PCT/FI1994/000568 1993-12-17 1994-12-16 Calculation of a scalar product in a direct-type fir filter WO1995017708A2 (en)

Priority Applications (5)

Application Number Priority Date Filing Date Title
US08/505,257 US6131105A (en) 1993-12-17 1994-12-16 Calculation of a scalar product in a direct-type FIR filter
DE69421073T DE69421073T2 (en) 1993-12-17 1994-12-16 CALCULATION OF A SCALAR PRODUCT IN A DIRECT NON-RECURSIVE FILTER
JP7517215A JPH08506953A (en) 1993-12-17 1994-12-16 Calculation of scalar product in direct type FIR filter
EP95903364A EP0685127B1 (en) 1993-12-17 1994-12-16 Calculation of a scalar product in a direct-type fir filter
KR1019950703435A KR960701409A (en) 1993-12-17 1994-12-16 Direct finite impulse response filter and how to calculate scalar product in it

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
FI935709A FI97002C (en) 1993-12-17 1993-12-17 Direct FIR filter, method for calculating point input in FIR filter and method for designing direct FIR filter
FI935709 1993-12-17

Publications (2)

Publication Number Publication Date
WO1995017708A2 true WO1995017708A2 (en) 1995-06-29
WO1995017708A3 WO1995017708A3 (en) 1995-07-20

Family

ID=8539143

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/FI1994/000568 WO1995017708A2 (en) 1993-12-17 1994-12-16 Calculation of a scalar product in a direct-type fir filter

Country Status (8)

Country Link
US (1) US6131105A (en)
EP (1) EP0685127B1 (en)
JP (1) JPH08506953A (en)
KR (1) KR960701409A (en)
AT (1) ATE185458T1 (en)
DE (1) DE69421073T2 (en)
FI (1) FI97002C (en)
WO (1) WO1995017708A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE19613732B4 (en) * 1996-03-29 2004-01-29 Siemens Ag Method for generating a measurement signal proportional to an electrical reactive power

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6272173B1 (en) * 1998-11-09 2001-08-07 Broadcom Corporation Efficient fir filter for high-speed communication
US6718355B2 (en) * 2001-02-05 2004-04-06 Conexant Systems, Inc. Systems and methods for a partial sum digital fir filter
US7986932B1 (en) * 2002-11-19 2011-07-26 National Semiconductor Corporation Fixed point FIR filter with adaptive truncation and clipping and wireless mobile station using same
US7860915B2 (en) 2003-12-29 2010-12-28 Xilinx, Inc. Digital signal processing circuit having a pattern circuit for determining termination conditions
US7853632B2 (en) 2003-12-29 2010-12-14 Xilinx, Inc. Architectural floorplan for a digital signal processing circuit
US7844653B2 (en) 2003-12-29 2010-11-30 Xilinx, Inc. Digital signal processing circuit having a pre-adder circuit
US7853636B2 (en) 2003-12-29 2010-12-14 Xilinx, Inc. Digital signal processing circuit having a pattern detector circuit for convergent rounding
US7480690B2 (en) 2003-12-29 2009-01-20 Xilinx, Inc. Arithmetic circuit with multiplexed addend inputs
US7865542B2 (en) 2003-12-29 2011-01-04 Xilinx, Inc. Digital signal processing block having a wide multiplexer
US7567997B2 (en) * 2003-12-29 2009-07-28 Xilinx, Inc. Applications of cascading DSP slices
US7882165B2 (en) 2003-12-29 2011-02-01 Xilinx, Inc. Digital signal processing element having an arithmetic logic unit
US8495122B2 (en) 2003-12-29 2013-07-23 Xilinx, Inc. Programmable device with dynamic DSP architecture
US7849119B2 (en) 2003-12-29 2010-12-07 Xilinx, Inc. Digital signal processing circuit having a pattern detector circuit
US7840630B2 (en) * 2003-12-29 2010-11-23 Xilinx, Inc. Arithmetic logic unit circuit
US7467175B2 (en) * 2003-12-29 2008-12-16 Xilinx, Inc. Programmable logic device with pipelined DSP slices
US7870182B2 (en) 2003-12-29 2011-01-11 Xilinx Inc. Digital signal processing circuit having an adder circuit with carry-outs
US7853634B2 (en) 2003-12-29 2010-12-14 Xilinx, Inc. Digital signal processing circuit having a SIMD circuit
US7472155B2 (en) 2003-12-29 2008-12-30 Xilinx, Inc. Programmable logic device with cascading DSP slices
US7840627B2 (en) 2003-12-29 2010-11-23 Xilinx, Inc. Digital signal processing circuit having input register blocks
US7744793B2 (en) 2005-09-06 2010-06-29 Lemaire Alexander B Apparatus and method for growing fullerene nanotube forests, and forming nanotube films, threads and composite structures therefrom
CN101242168B (en) * 2008-03-06 2010-06-02 清华大学 A realization method and device for FIR digital filter direct-connection
CN101360087B (en) * 2008-09-18 2010-09-29 清华大学 Low-complexity implementing method and apparatus for base-band forming SRRC digital filter
US8543635B2 (en) 2009-01-27 2013-09-24 Xilinx, Inc. Digital signal processing block with preadder stage
US8479133B2 (en) 2009-01-27 2013-07-02 Xilinx, Inc. Method of and circuit for implementing a filter in an integrated circuit

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0281101A2 (en) * 1987-03-03 1988-09-07 Nec Corporation Circuit for cancelling whole or part of a waveform using non-recursive and recursive filters
EP0344326A1 (en) * 1987-12-02 1989-12-06 Victor Company Of Japan, Ltd. Fir digital filter device
EP0384448A2 (en) * 1989-02-23 1990-08-29 Lsi Logic Corporation Digital filter
WO1994023493A1 (en) * 1993-04-05 1994-10-13 Saramaeki Tapio Method and arrangement in a transposed digital fir filter for multiplying a binary input signal with tap coefficients and a method for disigning a transposed digital filter

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2301870A1 (en) * 1975-02-19 1976-09-17 Majos Jacques HIGH DIGITAL FLOW MULTIPLIER CIRCUIT, ESPECIALLY FOR DIGITAL FILTER
US3979701A (en) * 1975-06-17 1976-09-07 Communications Satellite Corporation (Comsat) Non-recursive digital filter employing simple coefficients
GB2075299B (en) * 1980-04-22 1983-10-19 Casio Computer Co Ltd Digital filter device
DE3841268A1 (en) * 1988-12-08 1990-06-13 Thomson Brandt Gmbh DIGITAL FILTER
JPH0834406B2 (en) * 1990-06-28 1996-03-29 株式会社東芝 Input weighted transversal filter
US5481316A (en) * 1990-11-05 1996-01-02 Samsung Electronics Co., Ltd. System, apparatus and method for canceling televison ghost signals
GB9301704D0 (en) * 1993-01-28 1993-03-17 Signal Processors Ltd New digital modem design techniques
JP3203454B2 (en) * 1993-08-26 2001-08-27 日本プレシジョン・サーキッツ株式会社 Multiplier
US5383145A (en) * 1993-10-14 1995-01-17 Matsushita Electric Industrial Co., Ltd. Digital filter and digital signal processing system

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0281101A2 (en) * 1987-03-03 1988-09-07 Nec Corporation Circuit for cancelling whole or part of a waveform using non-recursive and recursive filters
EP0344326A1 (en) * 1987-12-02 1989-12-06 Victor Company Of Japan, Ltd. Fir digital filter device
EP0384448A2 (en) * 1989-02-23 1990-08-29 Lsi Logic Corporation Digital filter
WO1994023493A1 (en) * 1993-04-05 1994-10-13 Saramaeki Tapio Method and arrangement in a transposed digital fir filter for multiplying a binary input signal with tap coefficients and a method for disigning a transposed digital filter

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE19613732B4 (en) * 1996-03-29 2004-01-29 Siemens Ag Method for generating a measurement signal proportional to an electrical reactive power

Also Published As

Publication number Publication date
FI97002B (en) 1996-06-14
KR960701409A (en) 1996-02-24
EP0685127B1 (en) 1999-10-06
JPH08506953A (en) 1996-07-23
DE69421073T2 (en) 2000-02-03
FI935709A0 (en) 1993-12-17
DE69421073D1 (en) 1999-11-11
US6131105A (en) 2000-10-10
FI935709A (en) 1995-06-18
EP0685127A1 (en) 1995-12-06
FI97002C (en) 1996-09-25
ATE185458T1 (en) 1999-10-15
WO1995017708A3 (en) 1995-07-20

Similar Documents

Publication Publication Date Title
EP0685127B1 (en) Calculation of a scalar product in a direct-type fir filter
US5287299A (en) Method and apparatus for implementing a digital filter employing coefficients expressed as sums of 2 to an integer power
EP0122117B1 (en) Digital signal processors
US4811262A (en) Distributed arithmetic realization of second-order normal-form digital filter
US4130878A (en) Expandable 4 × 8 array multiplier
EP0146963B1 (en) Iir digital filter
US6370556B1 (en) Method and arrangement in a transposed digital FIR filter for multiplying a binary input signal with tap coefficients and a method for designing a transposed digital filter
Owens et al. A VLSI chip for the Winograd/prime factor algorithm to compute the discrete Fourier transform
US4947363A (en) Pipelined processor for implementing the least-mean-squares algorithm
US5016011A (en) Increased performance of digital integrated circuits by processing with multiple-bit-width digits
US5798954A (en) Digital filter device having a bit shifter unit
EP0559154A1 (en) Digital filter
US5025257A (en) Increased performance of digital integrated circuits by processing with multiple-bit-width digits
JPH10509011A (en) Improved digital filter
EP1119910B1 (en) Area efficient realization of coefficient architecture for bit-serial fir, iir filters and combinational/sequential logic structure with zero latency clock output
US4984187A (en) First order recursive digital filter without multiplier
JP2864598B2 (en) Digital arithmetic circuit
Ghanekar et al. A class of high-precision multiplier-free FIR filter realizations with periodically time-varying coefficients
Babasab et al. Novel Design of Optimized Digital Filter Using High Speed Adders
EP0213854A2 (en) Fixed-Coefficient serial multiplication and digital circuits therefor
JPH0666638B2 (en) Digital Filter
JPH0624310B2 (en) Digital Filter
JPH0795671B2 (en) Digital Filter
JPS59198020A (en) Digital signal processor
JPS6338739B2 (en)

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): CA JP KR US

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

AK Designated states

Kind code of ref document: A3

Designated state(s): CA JP KR US

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

WWE Wipo information: entry into national phase

Ref document number: 1995903364

Country of ref document: EP

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWP Wipo information: published in national office

Ref document number: 1995903364

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 08505257

Country of ref document: US

NENP Non-entry into the national phase

Ref country code: CA

WWG Wipo information: grant in national office

Ref document number: 1995903364

Country of ref document: EP