US20130083945A1 - Novel efficient digital microphone decimation filter architecture - Google Patents
Novel efficient digital microphone decimation filter architecture Download PDFInfo
- Publication number
- US20130083945A1 US20130083945A1 US13/633,092 US201213633092A US2013083945A1 US 20130083945 A1 US20130083945 A1 US 20130083945A1 US 201213633092 A US201213633092 A US 201213633092A US 2013083945 A1 US2013083945 A1 US 2013083945A1
- Authority
- US
- United States
- Prior art keywords
- input signal
- filtering system
- filters
- parallel circuit
- signal
- Prior art date
- Legal status (The legal status 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 status listed.)
- Granted
Links
- 238000001914 filtration Methods 0.000 claims abstract description 40
- 238000000034 method Methods 0.000 claims description 22
- 238000012545 processing Methods 0.000 claims description 14
- 230000008569 process Effects 0.000 claims description 7
- 230000005236 sound signal Effects 0.000 claims description 3
- 230000015654 memory Effects 0.000 description 19
- 230000008901 benefit Effects 0.000 description 5
- 238000007792 addition Methods 0.000 description 4
- 238000013461 design Methods 0.000 description 4
- 238000013459 approach Methods 0.000 description 3
- 230000000630 rising effect Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 230000007704 transition Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 238000010348 incorporation Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000002787 reinforcement Effects 0.000 description 1
- 229920006395 saturated elastomer Polymers 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H17/00—Networks using digital techniques
- H03H17/02—Frequency selective networks
- H03H17/0283—Filters characterised by the filter structure
- H03H17/0286—Combinations of filter structures
- H03H17/0288—Recursive, non-recursive, ladder, lattice structures
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H17/00—Networks using digital techniques
- H03H17/02—Frequency selective networks
- H03H17/04—Recursive filters
- H03H17/0416—Recursive filters with input-sampling frequency and output-delivery frequency which differ, e.g. extrapolation; Anti-aliasing
- H03H17/0427—Recursive filters with input-sampling frequency and output-delivery frequency which differ, e.g. extrapolation; Anti-aliasing characterized by the ratio between the input-sampling and output-delivery frequencies
- H03H17/0438—Recursive filters with input-sampling frequency and output-delivery frequency which differ, e.g. extrapolation; Anti-aliasing characterized by the ratio between the input-sampling and output-delivery frequencies the ratio being integer
- H03H17/045—Recursive filters with input-sampling frequency and output-delivery frequency which differ, e.g. extrapolation; Anti-aliasing characterized by the ratio between the input-sampling and output-delivery frequencies the ratio being integer where the output-delivery frequency is lower than the input sampling frequency, i.e. decimation
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H17/00—Networks using digital techniques
- H03H17/02—Frequency selective networks
- H03H17/0223—Computation saving measures; Accelerating measures
- H03H17/0233—Measures concerning the signal representation
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H17/00—Networks using digital techniques
- H03H17/02—Frequency selective networks
- H03H17/0223—Computation saving measures; Accelerating measures
- H03H2017/0247—Parallel structures using a slower clock
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H17/00—Networks using digital techniques
- H03H17/02—Frequency selective networks
- H03H17/04—Recursive filters
- H03H2017/0472—Recursive filters based on allpass structures
Definitions
- the present invention relates to processing signals. More particularly, the present invention relates to a system and method for processing signals pertaining to a filtering system or digital microphone decimation filter.
- Digital microphones accept a square wave clock at 64 times the ultimate sample rate of their audio signal, and return a stereo bitstream at that clock rate.
- the bitstream is the output of a 4 th order sigma-delta modulator.
- the task of a digital microphone interface is to filter the out-of-band noise from this bitstream and decimate it to the audio rate.
- a digital microphone interface accepts a bitstream at 64 times the output sample rate, and decimates it with filtering to the output sample rate to provide the output digital audio stream as a series of samples.
- Dattorro et al. U.S. Pat. No. 5,027,306, filed May 12, 1989, entitled “Decimation Filter As For A Sigma-Delta Analog-to-Digital Converter”
- this can be done by brute force using a single FIR filter. For 16 bit quality, they show this filter to be of approx order 2048 (symmetric: 4096).
- the invention provides a filtering system for processing an input signal that includes an input interface, a filtering module, and an output interface.
- the input interface is operable to receive the input signal in a bitstream.
- the filtering module is operable to process the input signal through a parallel circuit of filters, wherein the processing is performed using a single/common sample rate (e.g., 48 kHz, 32 kHz, etc.).
- the output interface is operable to generate an output signal based on the processed input signal.
- the invention provides a method for processing an input signal with a filtering system.
- the method includes (a) receiving the input signal in a bitstream; (b) processing the input signal through a parallel circuit of filters, wherein the processing is performed using a single sample rate; and (c) generating from the filtering system an output signal based on the processed input signal.
- the invention extends to a machine-readable medium embodying a sequence of instructions that, when executed by a machine (e.g., computer, processor, etc.), cause the machine to carry out any of the methods described herein.
- a machine e.g., computer, processor, etc.
- FIG. 1 is a diagrammatic representation of a filtering system (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.
- a filtering system e.g., digital microphone decimation filter architecture system
- FIG. 2 is a diagrammatic representation of a filtering system (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.
- a filtering system e.g., digital microphone decimation filter architecture system
- FIG. 3 a is a diagrammatic representation of a component (e.g., an IIR allpass filter implemented in “one-multiply” form) of the filtering system according to various embodiments of the present invention.
- a component e.g., an IIR allpass filter implemented in “one-multiply” form
- FIG. 3 b is a diagrammatic representation of a component (e.g., an IIR allpass filter implemented in “two-multiply” form) of the filtering system according to various embodiments of the present invention.
- a component e.g., an IIR allpass filter implemented in “two-multiply” form
- FIG. 4 is a diagrammatic representation of a component (e.g., FIR) of the filtering system (e.g., digital microphone decimation filter architecture) according to various embodiments of the present invention.
- FIR filtering system
- the invention can be implemented in numerous ways, including as a process, an apparatus, a system, a composition of matter, a computer readable medium such as a computer readable storage medium.
- theses implementations, or any other form that the invention may take, may be referred to as techniques.
- the order of the steps of disclosed processed may be altered within the scope of the invention.
- Digital microphones are often used in professional audio applications. Some of the advantages and shortcomings of working with digital microphones are described in a White Paper: “Digital Microphones and AES42” v2.1, May 11, 2010, which contents are incorporated by reference in their entirety herein.
- a new and more efficient digital microphone decimation filter architecture is presented.
- a key to this architecture is the use of two parallel filter paths. Each path operates at the output sample rate, and comprises a shorter FIR filter followed by a series of allpass stages.
- the FIR filter is designed to remove all but the last octave of out-of-band noise.
- the allpass stages e.g., implemented with IIR filters such as power symmetric elliptic filters
- IIR filters such as power symmetric elliptic filters
- the FIR input is a bitstream; thus, the FIR step comprises only addition operations, and no multiplier is required.
- the FIR filter in this architecture is considerably shorter (e.g., order 256), thus the shift register for storing the incoming bitstream is reduced by a factor of at least 8.
- this architecture does not use an intermediate sample rate.
- the allpass filters each operate at the output sample rate, and accept data from the FIR at the output sample rate. Thus the math can be done using a single accumulator.
- the allpass filters are of low complexity, requiring only a few multiplies per output sample. This means that an actual parallel multiplier is not required.
- FIG. 1 is a diagrammatic representation of a filtering system 100 (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.
- Filtering system 100 includes an input interface 101 , a filtering module 102 , and an output interface 103 .
- DMIC digital microphone
- Each FIR filter operate at the sample rate.
- Each FIR filter generates an output word (e.g., 22 bit at 48 kHz).
- the bitstream is then processed by two IIR Allpass filters.
- Each IIR Allpass filter operate at the sample rate and can change the phase but not the amplitude of the received signal.
- Each IIR Allpass filter generates an output word (e.g., 24 bit at 48 kHz), which are sum together to generate a digital audio output at the sample rate.
- filtering module 102 does not implement a multi-sample rate design, but rather a single rate design. The design criteria can be based on 16 bit quality—noise below ⁇ 96 db or ⁇ 100 db.
- a delay module is presented so that one of the FIR filter is operating at half the 64 ⁇ sample rate (therefore, 32 sample @ 48 kHz) out of step from the other FIR filter. Since IIR Allpass filters can change the phases, the output of the Allpass filters can be in phase for summation resulting in reinforcement of the sample point and cancellation of half the sample point away. Therefore, a more efficient filtering system can be realized.
- FIG. 2 is a diagrammatic representation of a filtering system 200 (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.
- Filtering system 200 which is similar to filtering system 100 , includes an input interface 201 , a filtering module 202 , and an output interface 203 .
- the input bitstream, represented as X i is a series of single bit values representing either a +1 or ⁇ 1 signal, having a sample rate 64 times the output sample rate.
- the output signal is represented as Y n , a stream of 24 bit words in 1.23 two's complement format at output sample rate.
- n and i The time relation between n and i is that i runs at a rate 64 times that of n, and that a minimum of 288 values of X i must be received for the calculation of Y n . It is convenient to define X 0 as the input sample received just prior to begin to compute Y 0 . Note that the actual delay between receipt of X i and the output of Y n is arbitrary. However, the delay should be consistent among all channels, and as small as practical.
- the output sample Y n is the sum of two substreams, Y0 n and Y1 n , also operating at the output sample rate.
- FIG. 3 a is a diagrammatic representation of a component 300 (e.g., an IIR allpass filter implemented in “one-multiply” form) of the filtering system according to various embodiments of the present invention.
- the “one-multiply” form requires a single multiplication and three addition operations.
- FIG. 3 a is a diagrammatic representation of a component 300 (e.g., an IIR allpass filter implemented in “one-multiply” form) of the filtering system according to various embodiments of the present invention.
- the “one-multiply” form requires a single multiplication and three addition operations.
- FIG. 3 b is a diagrammatic representation of a component 320 (e.g., an IIR allpass filter implemented in “two-multiply” form) of the filtering system according to various embodiments of the present invention.
- the “two-multiply” form requires two multiplications and two addition operations.
- FIGS. 3 a and 3 b are based on the 0c IIR Allpass filter in FIG. 2 , which can be adapted for any of the other IIR Allpass filters (e.g., 0a, 0b, 1a, 1b, 1c) in FIG. 2 as well.
- the results are mathematically equivalent. Both will be described here; the “two-multiply” form seems more appropriate for an optimal implementation.
- Each of the filter sections will be denoted by its substream number (0 or 1) and its section letter (a, b or c).
- Each filter has a coefficient k, and a delay memory Z n .
- substream 0 can be described:
- Y 1 n Z 1 c n ⁇ 1 +k 1c ( Y 0 b n ⁇ Z 1 c n ⁇ 1 )
- Y 1 b n Z 1 b n ⁇ 1 +k 1b ( Y 0 a n ⁇ Z 1 b n ⁇ 1 )
- the FIR filter outputs are the sums of products of the FIR filter coefficients C j times the corresponding input values X i .
- the two substreams use the same coefficients, but operate on data spaced one half output sample (or 32 input samples) apart.
- W 1 n C 0 X (64n ⁇ 287) +C 1 X (64n ⁇ 286) . . . +C 255 X (64n+32)
- a digital microphone decimation filter module/system implementing a preferred embodiment of the present invention processes N stereo streams of digital microphone data, at a clock rate R which can be either 3.072 MHz or 2.048 MHz.
- the module/system produces 2*N audio output streams, at a sample rate of 48 or 32 kHz respectively, compatible with the audio router.
- the digital microphone interface comprises a single clock output pin DMIC_MCLK producing a square wave at the selected clock rate R, and N input pins DMIC_SDIn accepting a bit stream from a stereo pair of digital microphones.
- DMIC_MCLK producing a square wave at the selected clock rate R
- N input pins DMIC_SDIn accepting a bit stream from a stereo pair of digital microphones.
- the control interface for the module/system comprises a rate select input DMIC_RATE which selects the value of R, and an enable bit for each of the N streams.
- DMIC_RATE which selects the value of R
- enable bit for each of the N streams.
- the module/system contains a single coefficient ROM (presumably a synthesized logic ROM) containing the C i coefficients.
- the coefficients are 18 bits, and because they are symmetric, only 128 coefficients are stored.
- the C i coefficients have maximum decimal significance of around 0.025. They are stored at 32 times their actual value, that is with a value slightly less than 1 for the largest coefficient (C 127 ), in 1.17 format.
- the factor of 32 comprises a factor of 2 because of the pairing of operations (see below), and a scale factor of 16.
- the input data stream X i is a stream of single bits, no multiplication is required in the computation of W n ; the sums can be produced by conditional additions or subtractions. Because the coefficients are symmetric, only 128 conditional add/subtracts are required per sum. If the two input samples associated with a given coefficient are different, the accumulator remains unchanged; if both are 1, two times the coefficient is added, and if both are 0, two times the coefficient is subtracted. Because of this pairing, the ROM value represents twice the value of the coefficient.
- the resulting Wi signal is guaranteed to have a value within [ ⁇ 1, 1] when the coefficients have their proper value; with scaling the value is now [ ⁇ 16, 16], implying that there are 4 bits of word growth in the sum of products operation.
- each of the two substreams will have its own accumulator.
- both accumulators for each channel are cleared.
- the 128 values of the coefficient ROM are sequentially accessed.
- the two shift register bits associated with that ROM are examined. For example, for substream 1 and C 1 , X (64n ⁇ 254) and X (64n ⁇ 1) are examined. If they are of different values, nothing is added into the accumulator. If they are both 1, then the coefficient is added to the accumulator; if they are both zero, the coefficient is subtracted from the accumulator.
- the accumulators contain the W0 n and W1 n values. Next the allpass filters can be implemented.
- FIG. 4 is a diagrammatic representation of a component 400 (e.g., FIR) of the filtering system (e.g., digital microphone decimation filter architecture) according to various embodiments of the present invention.
- a simple architecture of component 400 to implement the shift registers uses a 64 long, 1 bit wide input shift register to acquire 64 single bit values for each channel during each 48 kHz sample period. At the end of sample period prior to when Y n is being computed, this will contain values X (64n ⁇ 63) through X (64n) . These 64 bits are then shifted as a 64 bit word into a 64 bit wide ⁇ 5 word long compute shift register.
- this shift register contains X (64n ⁇ 319) through X (64n) . Note that 32 bits of the final word of this shift register (containing X (64n ⁇ 319) through X (64n ⁇ 288) ) are never used and need not exist.
- the allpass filter nodes can have word growth, so that even though the W0 n and W1 n values are limited to [ ⁇ 1, 1], the accumulator should have some headroom. Furthermore, since the multiplications in the allpass filters can produce fractional bits, some footroom is also beneficial. Two bits of footroom are sufficient.
- the two multiply allpass internal node is a highpass pole, so its gain is 1/(1 ⁇ k). Since the largest k we have is about 0.9, the gain is about 10, so 4 bits of headroom are necessary.
- the actual format of the accumulators is thus 5.23.
- the delay memories Zij n are in the same format.
- the 6 K ij coefficients are positive numbers, 16 bits in 0.16 format (see Appendix 2).
- the multiplications can be implemented as hard-coded shift and add operations, thus these coefficients are not stored in any ROM.
- the multiplications are implemented as adds and subtracts of the shifted multiplicand to the accumulator.
- the sequence of operations is as follows (the example is for substream 0):
- the accumulator now contains Za0 n ⁇ 1 and the delay memory contains Z0a n .
- the accumulator now contains Zb0 n ⁇ 1 and the delay memory contains Z0b n .
- the accumulator now contains Zc0 n ⁇ 1 and the delay memory contains Z0c 1 .
- the above process can be repeated for additional channels using the same accumulators but different delay memories. 256 clocks should be allocated for each channel.
- Control logic including coding of the ‘k’ coefficients
- the digital microphones all operate using an interface comprising a DMIC_MCLK signal, which is a square wave clock input into one or two digital microphone circuits, and a DMIC_SDI signal, which is the data output from the digital microphone circuits.
- a DMIC_MCLK signal which is a square wave clock input into one or two digital microphone circuits
- a DMIC_SDI signal which is the data output from the digital microphone circuits.
- Digital Microphone pads must be designed to accommodate the particular digital microphones used.
- the DMIC_MCLK signal is a 50% duty cycle square wave at 64 times the sample frequency. At 48 kHz sample rate, this means a clock of 3.072 MHz. Some microphones (e.g., a National product) have a maximum clock frequency of 2.4 MHz; this does not allow for full audio bandwidth operation. Some microphones also operate at a clock frequency of 2.048 MHz, and thus a sample rate of 32 kHz.
- the DMIC_SDI data input signal provides Pulse Density Modulation (PDM) information as “left” data in response to the falling edge of DMIC_MCLK, and “right” data in response to the rising edge.
- PDM Pulse Density Modulation
- the data delay time from the active edge of DMIC_MCLK to valid data on DMIC_SDI varies among the manufacturers, as does the hold time of valid data on DMIC_SDI following the subsequent DMIC_MCLK transition.
- An optimum interface should latch the DMIC_SDI data on the MCLK falling edge immediately prior to the next DMIC_MCLK transition. This will allow the maximum timing margin on the DMIC_SDI data delay, without placing any restriction on a positive value for its hold time.
- DMIC_SDI Data delay of 33 nsec, data hold of 7 nsec typical of Akustica parts.
- DMIC_SDI is sampled on the rising edge of DataStrobe.
- DMIC_SDI Data delay of 90 nsec, data hold of 65 nsec typical of National parts.
- DMIC_SDI is sampled on the rising edge of DataStrobe.
- Advantages of the present invention allow for an efficient combination of FIR and IIR filters that take advantage of a single bit input signal.
- the IIR filters allow the FIR to be more efficient by having lesser coefficients (e.g., order 256 vs order 4096). Further, due to the lesser coefficients, a single accumulator (e.g., register) can be used.
Landscapes
- Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Mathematical Physics (AREA)
- Filters That Use Time-Delay Elements (AREA)
- Complex Calculations (AREA)
Abstract
Description
- 1. Field of the Invention
- The present invention relates to processing signals. More particularly, the present invention relates to a system and method for processing signals pertaining to a filtering system or digital microphone decimation filter.
- 2. Description of the Related Art
- Digital microphones accept a square wave clock at 64 times the ultimate sample rate of their audio signal, and return a stereo bitstream at that clock rate. The bitstream is the output of a 4th order sigma-delta modulator. The task of a digital microphone interface is to filter the out-of-band noise from this bitstream and decimate it to the audio rate.
- In other words, a digital microphone interface accepts a bitstream at 64 times the output sample rate, and decimates it with filtering to the output sample rate to provide the output digital audio stream as a series of samples. As shown by Dattorro et al. (U.S. Pat. No. 5,027,306, filed May 12, 1989, entitled “Decimation Filter As For A Sigma-Delta Analog-to-Digital Converter”), which contents are incorporated by reference in their entirety herein, this can be done by brute force using a single FIR filter. For 16 bit quality, they show this filter to be of approx order 2048 (symmetric: 4096).
- What is desired is a more efficient and improved digital microphone decimation filter architecture system and method for processing signals thereof.
- In accordance with the invention, there is provided a more efficient and improved digital microphone decimation filter architecture.
- In one aspect, the invention provides a filtering system for processing an input signal that includes an input interface, a filtering module, and an output interface. The input interface is operable to receive the input signal in a bitstream. The filtering module is operable to process the input signal through a parallel circuit of filters, wherein the processing is performed using a single/common sample rate (e.g., 48 kHz, 32 kHz, etc.). The output interface is operable to generate an output signal based on the processed input signal.
- In another aspect, the invention provides a method for processing an input signal with a filtering system. The method includes (a) receiving the input signal in a bitstream; (b) processing the input signal through a parallel circuit of filters, wherein the processing is performed using a single sample rate; and (c) generating from the filtering system an output signal based on the processed input signal.
- The invention extends to a machine-readable medium embodying a sequence of instructions that, when executed by a machine (e.g., computer, processor, etc.), cause the machine to carry out any of the methods described herein.
- These and other features and advantages of the present invention are described below with reference to the drawings.
-
FIG. 1 is a diagrammatic representation of a filtering system (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention. -
FIG. 2 is a diagrammatic representation of a filtering system (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention. -
FIG. 3 a is a diagrammatic representation of a component (e.g., an IIR allpass filter implemented in “one-multiply” form) of the filtering system according to various embodiments of the present invention. -
FIG. 3 b is a diagrammatic representation of a component (e.g., an IIR allpass filter implemented in “two-multiply” form) of the filtering system according to various embodiments of the present invention. -
FIG. 4 is a diagrammatic representation of a component (e.g., FIR) of the filtering system (e.g., digital microphone decimation filter architecture) according to various embodiments of the present invention. - Reference will now be made in detail to preferred embodiments of the invention. Examples of the preferred embodiments are illustrated in the accompanying drawings. While the invention will be described in conjunction with these preferred embodiments, it will be understood that it is not intended to limit the invention to such preferred embodiments. On the contrary, it is intended to cover alternatives, modifications, and equivalents as may be included within the spirit and scope of the invention as defined by the appended claims. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. The present invention may be practiced without some or all of these specific details. In other instances, well known mechanisms have not been described in detail in order not to unnecessarily obscure the present invention.
- The invention can be implemented in numerous ways, including as a process, an apparatus, a system, a composition of matter, a computer readable medium such as a computer readable storage medium. In this specification, theses implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processed may be altered within the scope of the invention.
- It should be noted herein that throughout the various drawings like numerals refer to like parts. The various drawings illustrated and described herein are used to illustrate various features of the invention. To the extent that a particular feature is illustrated in one drawing and not another, except where otherwise indicated or where the structure inherently prohibits incorporation of the feature, it is to be understood that those features may be adapted to be included in the embodiments represented in the other figures, as if they were fully illustrated in those figures. Unless otherwise indicated, the drawings are not necessarily to scale. Any dimensions provided on the drawings are not intended to be limiting as to the scope of the invention but merely illustrative.
- Digital microphones are often used in professional audio applications. Some of the advantages and shortcomings of working with digital microphones are described in a White Paper: “Digital Microphones and AES42” v2.1, May 11, 2010, which contents are incorporated by reference in their entirety herein.
- According to various embodiments of the present invention, a new and more efficient digital microphone decimation filter architecture is presented. A key to this architecture is the use of two parallel filter paths. Each path operates at the output sample rate, and comprises a shorter FIR filter followed by a series of allpass stages. The FIR filter is designed to remove all but the last octave of out-of-band noise. The allpass stages (e.g., implemented with IIR filters such as power symmetric elliptic filters) are designed such that when the two paths are summed together, the out-of-band noise for the final octave cancels out, leaving only the desired signal. This architecture has several advantages over previous approaches. Like the approach of Dattorro et al., U.S. Pat. No. 5,027,306, which is incorporated by reference herein, the FIR input is a bitstream; thus, the FIR step comprises only addition operations, and no multiplier is required. In contrast to Dattorro et al., the FIR filter in this architecture is considerably shorter (e.g., order 256), thus the shift register for storing the incoming bitstream is reduced by a factor of at least 8. Unlike the traditional Cascaded Integrator Comb (CIC) approach, this architecture does not use an intermediate sample rate. The allpass filters each operate at the output sample rate, and accept data from the FIR at the output sample rate. Thus the math can be done using a single accumulator. Finally, the allpass filters are of low complexity, requiring only a few multiplies per output sample. This means that an actual parallel multiplier is not required.
-
FIG. 1 is a diagrammatic representation of a filtering system 100 (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.Filtering system 100 includes aninput interface 101, afiltering module 102, and anoutput interface 103. From the digital microphone (DMIC), a bitstream at 64× sample rate (e.g., 64×48 kHz=3.072 MHz) at 1 bit wide is received atinput interface 101, which is then processed by two parallel FIR filters. Each FIR filter operate at the sample rate. Each FIR filter generates an output word (e.g., 22 bit at 48 kHz). The bitstream is then processed by two IIR Allpass filters. Each IIR Allpass filter operate at the sample rate and can change the phase but not the amplitude of the received signal. Each IIR Allpass filter generates an output word (e.g., 24 bit at 48 kHz), which are sum together to generate a digital audio output at the sample rate. It is appreciated that according to various embodiments,filtering module 102 does not implement a multi-sample rate design, but rather a single rate design. The design criteria can be based on 16 bit quality—noise below −96 db or −100 db. A delay module is presented so that one of the FIR filter is operating at half the 64× sample rate (therefore, 32 sample @ 48 kHz) out of step from the other FIR filter. Since IIR Allpass filters can change the phases, the output of the Allpass filters can be in phase for summation resulting in reinforcement of the sample point and cancellation of half the sample point away. Therefore, a more efficient filtering system can be realized. - Detailed Mathematical Basis
-
FIG. 2 is a diagrammatic representation of a filtering system 200 (e.g., digital microphone decimation filter architecture system) according to various embodiments of the present invention.Filtering system 200, which is similar tofiltering system 100, includes aninput interface 201, afiltering module 202, and anoutput interface 203. The input bitstream, represented as Xi, is a series of single bit values representing either a +1 or −1 signal, having asample rate 64 times the output sample rate. The output signal is represented as Yn, a stream of 24 bit words in 1.23 two's complement format at output sample rate. The time relation between n and i is that i runs at arate 64 times that of n, and that a minimum of 288 values of Xi must be received for the calculation of Yn. It is convenient to define X0 as the input sample received just prior to begin to compute Y0. Note that the actual delay between receipt of Xi and the output of Yn is arbitrary. However, the delay should be consistent among all channels, and as small as practical. - The output sample Yn is the sum of two substreams, Y0n and Y1n, also operating at the output sample rate. In other words:
-
Y n =Y0n +Y1n - Each of these substreams is the output of a series of three allpass filters operating at the output sample rate. Each of the six allpass filters has its own filter coefficient k, which is a positive number less than one. Allpass filters can be implemented in a number of ways. For example,
FIG. 3 a is a diagrammatic representation of a component 300 (e.g., an IIR allpass filter implemented in “one-multiply” form) of the filtering system according to various embodiments of the present invention. The “one-multiply” form requires a single multiplication and three addition operations. For another example,FIG. 3 b is a diagrammatic representation of a component 320 (e.g., an IIR allpass filter implemented in “two-multiply” form) of the filtering system according to various embodiments of the present invention. The “two-multiply” form requires two multiplications and two addition operations. For exemplary purposes, bothFIGS. 3 a and 3 b are based on the 0c IIR Allpass filter inFIG. 2 , which can be adapted for any of the other IIR Allpass filters (e.g., 0a, 0b, 1a, 1b, 1c) inFIG. 2 as well. The results are mathematically equivalent. Both will be described here; the “two-multiply” form seems more appropriate for an optimal implementation. - Each of the filter sections will be denoted by its substream number (0 or 1) and its section letter (a, b or c). Each filter has a coefficient k, and a delay memory Zn. In the one multiply form,
substream 0 can be described: -
Y0n =Z0c n−1 +k 0c(Y0b n −Z0c n−1) -
Z0c n =Y0b n +k 0c(Y0b n −Z0c n−1) -
Y0b n =Z0b n−1 +k 0b(Y0a n −Z0b n−1) -
Z0b n =Y0a n +k 0b(Y0a n −Z0b n−1) -
Y0a n =Z0a n−1 +k 0a(W0n −Z0a n−1) -
Z0a n =W0n +k 0a(W0n −Z0a n−1) - Or in the two multiply form:
-
Y0n =Z0c n−1 +k 0c Z0c n -
Z0c n =Y0b n −k 0c Z0c n−1 -
Y0b n =Z0b n−1 +k 0b Z0b n -
Z0b n =Y0a n −k 0b Z0b n−1 -
Y0a n =Z0a n−1 +k 0a Z0a n -
Z0a n =W0n −k 0a Z0a n−1 - In both cases W0n is the output of the FIR filter for
substream 0.Substream 1 is similar: -
Y1n =Z1c n−1 +k 1c(Y0b n −Z1c n−1) -
Z1c n =Y1b n +k 1c(Y0b n −Z1c n−1) -
Y1b n =Z1b n−1 +k 1b(Y0a n −Z1b n−1) -
Z1b n =Y1a n +k 1b(Y0a n −Z1b n−1) -
Y1a n =Z1a n−1 +k 1a(W0n −Z1a n−1) -
Z1a n =W1n +k 1a(W0n −Z1a n−1) - Or in the two multiply form:
-
Y1n =Z1c n−1 +k 1c Z1c n -
Z1c n =Y1b n −k 1c Z1c n−1 -
Y1b n =Z1b n−1 +k 1b Z1b n -
Z1b n =Y1a n −k 1b Z1b n−1 -
Y1a n =Z1a n−1 +k 1a Z1a n -
Z1a n =W1n −k 1a Z1a n−1 - The FIR filter outputs are the sums of products of the FIR filter coefficients Cj times the corresponding input values Xi. The 256 coefficients are even (symmetric with or without a central value), so that C0=C255, C1=C254, etc. The two substreams use the same coefficients, but operate on data spaced one half output sample (or 32 input samples) apart. Thus:
-
W0n =C 0 X (64n−255) +C 1 X (64n−254) . . . +C 255 X (64n) -
W1n =C 0 X (64n−287) +C 1 X (64n−286) . . . +C 255 X (64n+32) - Implementation
- A digital microphone decimation filter module/system implementing a preferred embodiment of the present invention processes N stereo streams of digital microphone data, at a clock rate R which can be either 3.072 MHz or 2.048 MHz. The module/system produces 2*N audio output streams, at a sample rate of 48 or 32 kHz respectively, compatible with the audio router.
- The digital microphone interface comprises a single clock output pin DMIC_MCLK producing a square wave at the selected clock rate R, and N input pins DMIC_SDIn accepting a bit stream from a stereo pair of digital microphones. The format of this data is described in
Appendix 1 below. - The control interface for the module/system comprises a rate select input DMIC_RATE which selects the value of R, and an enable bit for each of the N streams. When the enable bit is negated, the associated DMIC_SDI input is ignored, the audio data output is not computed, and the associated delay registers are cleared to zero. When all enable bits are negated, the DMIC_MCLK becomes quiescent at a zero value.
- The module/system contains a single coefficient ROM (presumably a synthesized logic ROM) containing the Ci coefficients. The coefficients are 18 bits, and because they are symmetric, only 128 coefficients are stored. The Ci coefficients have maximum decimal significance of around 0.025. They are stored at 32 times their actual value, that is with a value slightly less than 1 for the largest coefficient (C127), in 1.17 format. The factor of 32 comprises a factor of 2 because of the pairing of operations (see below), and a scale factor of 16.
- Because the input data stream Xi is a stream of single bits, no multiplication is required in the computation of Wn; the sums can be produced by conditional additions or subtractions. Because the coefficients are symmetric, only 128 conditional add/subtracts are required per sum. If the two input samples associated with a given coefficient are different, the accumulator remains unchanged; if both are 1, two times the coefficient is added, and if both are 0, two times the coefficient is subtracted. Because of this pairing, the ROM value represents twice the value of the coefficient.
- The resulting Wi signal is guaranteed to have a value within [−1, 1] when the coefficients have their proper value; with scaling the value is now [−16, 16], implying that there are 4 bits of word growth in the sum of products operation.
- Were the accumulator to merely accommodate the FIR operation, it must have 22 bits, in 5.17 format with scaling, or equivalently 1.21 format when the result is scaled back to unity gain.
- Based on the above, each of the two substreams will have its own accumulator. At the beginning of each 48 kHz sample period, both accumulators for each channel are cleared. Then the 128 values of the coefficient ROM are sequentially accessed. For each substream for each channel, the two shift register bits associated with that ROM are examined. For example, for
substream 1 and C1, X(64n−254) and X(64n−1) are examined. If they are of different values, nothing is added into the accumulator. If they are both 1, then the coefficient is added to the accumulator; if they are both zero, the coefficient is subtracted from the accumulator. After all 128 coefficients are processed, the accumulators contain the W0n and W1n values. Next the allpass filters can be implemented. -
FIG. 4 is a diagrammatic representation of a component 400 (e.g., FIR) of the filtering system (e.g., digital microphone decimation filter architecture) according to various embodiments of the present invention. A simple architecture ofcomponent 400 to implement the shift registers uses a 64 long, 1 bit wide input shift register to acquire 64 single bit values for each channel during each 48 kHz sample period. At the end of sample period prior to when Yn is being computed, this will contain values X(64n−63) through X(64n). These 64 bits are then shifted as a 64 bit word into a 64 bit wide×5 word long compute shift register. During the sample period when Yn is being computed, this contains X(64n−319) through X(64n). Note that 32 bits of the final word of this shift register (containing X(64n−319) through X(64n−288)) are never used and need not exist. - The allpass filter nodes can have word growth, so that even though the W0n and W1n values are limited to [−1, 1], the accumulator should have some headroom. Furthermore, since the multiplications in the allpass filters can produce fractional bits, some footroom is also beneficial. Two bits of footroom are sufficient. The two multiply allpass internal node is a highpass pole, so its gain is 1/(1−k). Since the largest k we have is about 0.9, the gain is about 10, so 4 bits of headroom are necessary. The actual format of the accumulators is thus 5.23. The delay memories Zijn are in the same format.
- The 6 Kij coefficients are positive numbers, 16 bits in 0.16 format (see Appendix 2). The multiplications can be implemented as hard-coded shift and add operations, thus these coefficients are not stored in any ROM.
- Use of the two multiply form of the allpass allows storage to be minimized. The multiplications are implemented as adds and subtracts of the shifted multiplicand to the accumulator. The sequence of operations is as follows (the example is for substream 0):
- Begin with W0n in the accumulator, and Za0n−1 in the ‘a’ delay memory, Zb0n−1 in the ‘b’ delay memory, and Zc0n−1 in the ‘c’ delay memory.
- Multiply the contents of the ‘a’ delay memory by −k0a and accumulate the result. The accumulator now contains W0n−k0aZ0an−1.=Z0an.
- Swap the accumulator and the ‘a’ delay memory. The accumulator now contains Za0n−1 and the delay memory contains Z0an.
- Multiply the contents of the ‘a’ delay memory by k0a and accumulate the result. The accumulator now contains Za0n−1+k0aZ0an.=Y0an.
- Multiply the contents of the ‘b’ delay memory by −k0b and accumulate the result. The accumulator now contains Y0an−k0bZ0bn−1.=Z0bn.
- Swap the accumulator and the ‘b’ delay memory. The accumulator now contains Zb0n−1 and the delay memory contains Z0bn.
- Multiply the contents of the ‘b’ delay memory by k0b and accumulate the result. The accumulator now contains Zb0n−1+k0bZ0bn.=Y0bn.
- Multiply the contents of the ‘c’ delay memory by −k0c and accumulate the result. The accumulator now contains Y0bn−k0cZ0cn−1.=Z0cn.
- Swap the accumulator and the ‘c’ delay memory. The accumulator now contains Zc0n−1 and the delay memory contains Z0c1.
- Multiply the contents of the ‘c’ delay memory by k0c and accumulate the result. The accumulator now contains Zc0n−1+k0cZ0cn.=Y0n.
- In parallel, the analogous process is done to
substream 1. - Finally, the two substreams are added together, the result is saturated from its 5.23 format to [−1, 1] as 1.23 format, and then output to the audio router.
- The above process can be repeated for additional channels using the same accumulators but different delay memories. 256 clocks should be allocated for each channel.
- The Total Facilities Required:
-
- Shared Resources for All Channels:
- 18 bit by 128 word ROM
- Control logic including coding of the ‘k’ coefficients
-
- Per Channel Resources:
- 352 bits of shift register and associated muxes
- 24 bits of output register
- 168 bits of delay memory and associated muxes
-
- Time Shared Among Channels for Each Accumulator Pair:
- 56 bits of accumulator
- 2 28 bit adder/subtractors
- Quality
- This implementation has been designed to meet “16 bit” quality standards. It is possible to use a shorter FIR and shorter coefficient words to decrease the resources further at the cost of audio quality. Such tradeoffs could be more thoroughly investigated in MATLAB.
- Appendix 1: Digital Microphone Interface Format
- The digital microphones all operate using an interface comprising a DMIC_MCLK signal, which is a square wave clock input into one or two digital microphone circuits, and a DMIC_SDI signal, which is the data output from the digital microphone circuits. When two mics are used, they are configured so that the DMIC_SDI from both mics is multiplexed into one signal line for the stereo configuration.
- a. Signal Voltages and Levels
- Digital Microphone pads must be designed to accommodate the particular digital microphones used.
- b. Signal Timing
- The DMIC_MCLK signal is a 50% duty cycle square wave at 64 times the sample frequency. At 48 kHz sample rate, this means a clock of 3.072 MHz. Some microphones (e.g., a National product) have a maximum clock frequency of 2.4 MHz; this does not allow for full audio bandwidth operation. Some microphones also operate at a clock frequency of 2.048 MHz, and thus a sample rate of 32 kHz.
- The DMIC_SDI data input signal provides Pulse Density Modulation (PDM) information as “left” data in response to the falling edge of DMIC_MCLK, and “right” data in response to the rising edge. The data delay time from the active edge of DMIC_MCLK to valid data on DMIC_SDI varies among the manufacturers, as does the hold time of valid data on DMIC_SDI following the subsequent DMIC_MCLK transition. An optimum interface should latch the DMIC_SDI data on the MCLK falling edge immediately prior to the next DMIC_MCLK transition. This will allow the maximum timing margin on the DMIC_SDI data delay, without placing any restriction on a positive value for its hold time. Assuming no signal skew, this design allows for data delay timing margins of 89 nsec and 113.25 nsec, and data hold margins of 48 nsec and 106 nsec respectively for Akustica and National parts. See the timing diagrams below for details.
- Note that while some microphones specify that there is a finite (typically 200 msec) “data invalid” time during power-up, there is no need to deal with this in the hardware.
- 48 kHz Sample Rate, 3.072 MHz DMIC_MCLK
- MCLK xssazzxssazzxssazzxssazzxssazzxssazzxs
- DMIC_MCLK azzzzzzzzzzzxsssssssssssazzzzzzzzzzzxs
- DataStrobe zzzzzzzzzxssazzzzzzzzxssazzzzzzzzxssaz
-
- 33 nsec 0=0=7 nsec
- Data delay of 33 nsec, data hold of 7 nsec typical of Akustica parts. DMIC_SDI is sampled on the rising edge of DataStrobe.
- 32 kHz Sample Rate, 2.048 MHz DMIC_MCLK
- MCLK xsazxsazxsazxsazxsazxsazxsazxsazxsazxs
- DMIC_MCLK azzzzzzzzzzzxsssssssssssazzzzzzzzzzzxs
- DataStrobe zzzzzzzzzzxsazzzzzzzzzxsazzzzzzzzzxsaz
-
- 90 nsec 0=0=65 nsec
- Data delay of 90 nsec, data hold of 65 nsec typical of National parts. DMIC_SDI is sampled on the rising edge of DataStrobe.
- Appendix 2: Allpass Filter Coefficients
- These coefficients correspond to requirements of 96 dB attenuation at 28 kHz:
-
k 0a=2894/65536=0.0442 -
k 0b=21667/65536=0.3306 -
k 0c=46002/65536=0.7019 -
k 1a=10755/65536=0.1641 -
k 1b=33747/65536=0.5149 -
k 1c=58644/65536=0.8948 - Appendix 3: FIR Filter Coefficients
- These coefficients correspond to requirements of +/−0.1 dB ripple 0-20 kHz, 100 dB attenuation 76 kHz to 116 kHz, and 130 dB above 124 kHz. All are expressed as integer values. The actual coefficients are stored effectively as 1.17 format (divided by 131072), and the original FIR values are 1/32 of the these (divided by 4194304): C0=1; C1=2; C2=3; C3=4; C4=6; C5=8; C6=11; C7=15; C8=20; C9=26; C10=33; C11=41; C12=51; C13=63; C14=76; C15=91; C16=109; C17=128; C18=149; C19=173; C20=198; C21=225; C22=254; C23=285; C24=317; C25=350; C26=383; C27=416; C28=448; C29=479; C30=507; C31=533; C32=554; C33=569; C34=578; C35=579; C36=571; C37=553; C38=522; C39=478; C40=418; C41=341; C42=247; C43=132; C44=−4; C45=−163; C46=−345; C47=−553; C48=−787; C49=−1048; C50=−1336; C51=−1652; C52=−1996; C53=−2368; C54=−2766; C55=−3190; C56=−3638; C57=−4109; C58=−4601; C59=−5109; C60=−5632; C61=−6166; C62=−6706; C63=−7248; C64=−7786; C65=−8315; C66=−8828; C67=−9320; C68=−9783; C69=−10210; C70=−10593; C71=−10924; C72=−11195; C73=−11397; C74=−11522; C75=−11562; C76=−11507; C77=−11349; C78=−11080; C79=−10692; C80=−10176; C81=−9526; C82=−8735; C83=−7796; C84=−6703; C85=−5452; C86=−4039; C87=−2461; C88=−714; C89=1201; C90=3286; C91=5539; C92=7958; C93=10540; C94=13280; C95=16172; C96=19210; C97=22384; C98=25686; C99=29105; C100=32630; C101=36246; C102=39940; C103=43698; C104=47504; C105=51340; C106=55191; C107=59038; C108=62862; C109=66646; C110=70370; C111=74016; C112=77565; C113=80999; C114=84299; C115=87447; C116=90426; C117=93220; C118=95814; C119=98193; C120=100343; C121=102252; C122=103909; C123=105305; C124=106432; C125=107283; C126=107853; C127=108138.
- Advantages of the present invention allow for an efficient combination of FIR and IIR filters that take advantage of a single bit input signal. The IIR filters allow the FIR to be more efficient by having lesser coefficients (e.g.,
order 256 vs order 4096). Further, due to the lesser coefficients, a single accumulator (e.g., register) can be used. - Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
Claims (20)
Priority Applications (4)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US13/633,092 US9337805B2 (en) | 2011-09-30 | 2012-10-01 | Efficient digital microphone decimation filter architecture |
| CN201280047016.7A CN103828235B (en) | 2011-09-30 | 2012-10-01 | New and effective digital microphone decimation filter framework |
| SG11201400789UA SG11201400789UA (en) | 2011-09-30 | 2012-10-01 | A novel efficient digital microphone decimation filter architecture |
| PCT/US2012/058373 WO2013049858A1 (en) | 2011-09-30 | 2012-10-01 | A novel efficient digital microphone decimation filter architecture |
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US201161542098P | 2011-09-30 | 2011-09-30 | |
| US13/633,092 US9337805B2 (en) | 2011-09-30 | 2012-10-01 | Efficient digital microphone decimation filter architecture |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| US20130083945A1 true US20130083945A1 (en) | 2013-04-04 |
| US9337805B2 US9337805B2 (en) | 2016-05-10 |
Family
ID=47992619
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US13/633,092 Active 2033-08-19 US9337805B2 (en) | 2011-09-30 | 2012-10-01 | Efficient digital microphone decimation filter architecture |
Country Status (5)
| Country | Link |
|---|---|
| US (1) | US9337805B2 (en) |
| EP (1) | EP2761749B1 (en) |
| CN (1) | CN103828235B (en) |
| SG (1) | SG11201400789UA (en) |
| WO (1) | WO2013049858A1 (en) |
Cited By (6)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20160057535A1 (en) * | 2013-03-26 | 2016-02-25 | Lachlan Paul BARRATT | Audio filtering with virtual sample rate increases |
| US20200133256A1 (en) * | 2018-05-07 | 2020-04-30 | Strong Force Iot Portfolio 2016, Llc | Methods and systems for sampling and storing machine signals for analytics and maintenance using the industrial internet of things |
| CN116325561A (en) * | 2020-10-15 | 2023-06-23 | 罗伯特·博世有限公司 | Connecting device for a device for charging an electric energy store, charging device and electric vehicle |
| US12249325B2 (en) | 2020-05-28 | 2025-03-11 | Nokia Technologies Oy | Decimator for audio signals |
| US12276420B2 (en) | 2016-02-03 | 2025-04-15 | Strong Force Iot Portfolio 2016, Llc | Industrial internet of things smart heating systems and methods that produce and use hydrogen fuel |
| US12353181B2 (en) | 2019-01-13 | 2025-07-08 | Strong Force Iot Portfolio 2016, Llc | Systems for monitoring and managing industrial settings |
Families Citing this family (1)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US10755721B1 (en) * | 2019-04-30 | 2020-08-25 | Synaptics Incorporated | Multichannel, multirate, lattice wave filter systems and methods |
Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20080256157A1 (en) * | 2006-12-07 | 2008-10-16 | Bostaman Anas Bin Muhamad | Information Processing Device and Information Processing Method |
| US7774394B2 (en) * | 2006-08-18 | 2010-08-10 | Infineon Technologies Ag | Exponentiated polyphase digital filter |
Family Cites Families (11)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| GB2179816B (en) | 1985-08-28 | 1990-01-10 | Plessey Co Plc | Interpolator/decimator filter structure |
| US5027306A (en) | 1989-05-12 | 1991-06-25 | Dattorro Jon C | Decimation filter as for a sigma-delta analog-to-digital converter |
| US5258939A (en) | 1991-10-10 | 1993-11-02 | Harris Corporation | Fold and decimate filter architecture |
| US5900570A (en) | 1995-04-07 | 1999-05-04 | Creative Technology, Ltd. | Method and apparatus for synthesizing musical sounds by frequency modulation using a filter |
| US5787125A (en) | 1996-05-06 | 1998-07-28 | Motorola, Inc. | Apparatus for deriving in-phase and quadrature-phase baseband signals from a communication signal |
| US7280878B1 (en) * | 1999-10-27 | 2007-10-09 | Creative Technology Ltd | Sample rate converter having distributed filtering |
| JP3899966B2 (en) * | 2002-03-14 | 2007-03-28 | 松下電器産業株式会社 | Digital signal receiver |
| US7415542B2 (en) * | 2004-06-18 | 2008-08-19 | Analog Devices, Inc. | Micro-programmable filter engine having plurality of filter elements interconnected in chain configuration wherein engine supports multiple filters from filter elements |
| US7856283B2 (en) | 2005-12-13 | 2010-12-21 | Sigmatel, Inc. | Digital microphone interface, audio codec and methods for use therewith |
| WO2007084259A2 (en) * | 2005-12-16 | 2007-07-26 | Sirf Technology, Inc. | Multi-standard multi-rate filter |
| KR101669084B1 (en) | 2009-02-24 | 2016-10-25 | 삼성전자주식회사 | Method and apparatus for digital up or down conversion using infinite impulse response filter |
-
2012
- 2012-10-01 EP EP12836550.9A patent/EP2761749B1/en active Active
- 2012-10-01 CN CN201280047016.7A patent/CN103828235B/en active Active
- 2012-10-01 WO PCT/US2012/058373 patent/WO2013049858A1/en not_active Ceased
- 2012-10-01 US US13/633,092 patent/US9337805B2/en active Active
- 2012-10-01 SG SG11201400789UA patent/SG11201400789UA/en unknown
Patent Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US7774394B2 (en) * | 2006-08-18 | 2010-08-10 | Infineon Technologies Ag | Exponentiated polyphase digital filter |
| US20080256157A1 (en) * | 2006-12-07 | 2008-10-16 | Bostaman Anas Bin Muhamad | Information Processing Device and Information Processing Method |
Cited By (9)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20160057535A1 (en) * | 2013-03-26 | 2016-02-25 | Lachlan Paul BARRATT | Audio filtering with virtual sample rate increases |
| US9949029B2 (en) * | 2013-03-26 | 2018-04-17 | Lachlan Paul BARRATT | Audio filtering with virtual sample rate increases |
| US12276420B2 (en) | 2016-02-03 | 2025-04-15 | Strong Force Iot Portfolio 2016, Llc | Industrial internet of things smart heating systems and methods that produce and use hydrogen fuel |
| US20200133256A1 (en) * | 2018-05-07 | 2020-04-30 | Strong Force Iot Portfolio 2016, Llc | Methods and systems for sampling and storing machine signals for analytics and maintenance using the industrial internet of things |
| US12353203B2 (en) | 2018-05-07 | 2025-07-08 | Strong Force Iot Portfolio 2016, Llc | Methods and systems for data collection, learning, and streaming of machine signals for analytics and maintenance using the industrial Internet of Things |
| US12353181B2 (en) | 2019-01-13 | 2025-07-08 | Strong Force Iot Portfolio 2016, Llc | Systems for monitoring and managing industrial settings |
| US12249325B2 (en) | 2020-05-28 | 2025-03-11 | Nokia Technologies Oy | Decimator for audio signals |
| CN116325561A (en) * | 2020-10-15 | 2023-06-23 | 罗伯特·博世有限公司 | Connecting device for a device for charging an electric energy store, charging device and electric vehicle |
| US12187144B2 (en) | 2020-10-15 | 2025-01-07 | Robert Bosch Gmbh | Connection device for a device for charging an electrical energy accumulator, charging device and electric vehicle |
Also Published As
| Publication number | Publication date |
|---|---|
| WO2013049858A1 (en) | 2013-04-04 |
| CN103828235B (en) | 2017-03-15 |
| US9337805B2 (en) | 2016-05-10 |
| CN103828235A (en) | 2014-05-28 |
| EP2761749B1 (en) | 2021-07-21 |
| EP2761749A4 (en) | 2015-05-27 |
| EP2761749A1 (en) | 2014-08-06 |
| SG11201400789UA (en) | 2014-04-28 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US9337805B2 (en) | Efficient digital microphone decimation filter architecture | |
| EP0695032B1 (en) | Digital-to-digital sample rate converter | |
| US6260053B1 (en) | Efficient and scalable FIR filter architecture for decimation | |
| EP1639703B1 (en) | Rational sample rate conversion | |
| JPH11261376A (en) | Digital iir filter by few multipliers | |
| US6392576B1 (en) | Multiplierless interpolator for a delta-sigma digital to analog converter | |
| US7102548B1 (en) | Cascaded integrator comb filter with arbitrary integer decimation value and scaling for unity gain | |
| WO2008045713A2 (en) | Methods and systems for implementing a digital-to-analog converter | |
| Kumar et al. | Exploiting coefficient symmetry in conventional polyphase FIR filters | |
| US7196648B1 (en) | Non-integer decimation using cascaded intergrator-comb filter | |
| US9954514B2 (en) | Output range for interpolation architectures employing a cascaded integrator-comb (CIC) filter with a multiplier | |
| US7492848B2 (en) | Method and apparatus for efficient multi-stage FIR filters | |
| US20060212503A1 (en) | Multi-channel sample rate conversion method | |
| CN115882820A (en) | Filter circuit and analog-to-digital converter | |
| US6501406B1 (en) | Digital filter | |
| US7292630B2 (en) | Limit-cycle-free FIR/IIR halfband digital filter with shared registers for high-speed sigma-delta A/D and D/A converters | |
| US8645442B2 (en) | Method and apparatus for a finite impulse response filter | |
| US7283076B1 (en) | Digital non-integer sample/hold implemented using virtual filtering | |
| US7242326B1 (en) | Sample rate conversion combined with filter | |
| US20020010727A1 (en) | Area efficient fir filter with programmable coefficients | |
| Zhu et al. | ASIC implementation architecture for pulse shaping FIR filters in 3G mobile communications | |
| JPH0884048A (en) | Sampling rate converter | |
| US10250416B2 (en) | Recursive difference filter realization of digital filters | |
| Srivastava et al. | Design of An Optimized CIC Compensation Filter Using a FIR Filter Based on CSD Grouping | |
| Shanmugaraj et al. | Hearing aid speech signal enhancement via N-parallel FIR-multiplying polynomials for Tamil language dialect syllable ripple and transition variation |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AS | Assignment |
Owner name: CREATIVE TECHNOLOGY LTD, SINGAPORE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROSSUM, DAVID PHILIP;REEL/FRAME:029337/0641 Effective date: 20121118 |
|
| STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
| FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO SMALL (ORIGINAL EVENT CODE: SMAL); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
| MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 4 |
|
| MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2552); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 8 |