[go: up one dir, main page]

US20190214972A1 - Methods and apparatus for efficient linear combiner - Google Patents

Methods and apparatus for efficient linear combiner Download PDF

Info

Publication number
US20190214972A1
US20190214972A1 US16/299,299 US201916299299A US2019214972A1 US 20190214972 A1 US20190214972 A1 US 20190214972A1 US 201916299299 A US201916299299 A US 201916299299A US 2019214972 A1 US2019214972 A1 US 2019214972A1
Authority
US
United States
Prior art keywords
output
tile
adc
sub
weight
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.)
Abandoned
Application number
US16/299,299
Inventor
Jaiganesh Balakrishnan
Sthanunathan RAMAKRISHNAN
Pooja Sundar
Sashidharan Venkatraman
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Texas Instruments Inc
Original Assignee
Texas Instruments Inc
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 Texas Instruments Inc filed Critical Texas Instruments Inc
Priority to US16/299,299 priority Critical patent/US20190214972A1/en
Publication of US20190214972A1 publication Critical patent/US20190214972A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03HIMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
    • H03H17/00Networks using digital techniques
    • H03H17/02Frequency selective networks
    • H03H17/0219Compensation of undesirable effects, e.g. quantisation noise, overflow
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F5/00Methods or arrangements for data conversion without changing the order or content of the data handled
    • G06F5/01Methods or arrangements for data conversion without changing the order or content of the data handled for shifting, e.g. justifying, scaling, normalising
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/38Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
    • G06F7/48Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
    • G06F7/544Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices for evaluating functions by calculation
    • G06F7/5443Sum of products
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03HIMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
    • H03H17/00Networks using digital techniques
    • H03H17/0045Impedance matching networks
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03HIMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
    • H03H17/00Networks using digital techniques
    • H03H17/02Frequency selective networks
    • H03H17/06Non-recursive filters
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M1/00Analogue/digital conversion; Digital/analogue conversion
    • H03M1/06Continuously compensating for, or preventing, undesired influence of physical parameters
    • H03M1/0617Continuously compensating for, or preventing, undesired influence of physical parameters characterised by the use of methods or means not specific to a particular type of detrimental influence
    • H03M1/0626Continuously compensating for, or preventing, undesired influence of physical parameters characterised by the use of methods or means not specific to a particular type of detrimental influence by filtering
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M1/00Analogue/digital conversion; Digital/analogue conversion
    • H03M1/12Analogue/digital converters
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M1/00Analogue/digital conversion; Digital/analogue conversion
    • H03M1/12Analogue/digital converters
    • H03M1/1205Multiplexed conversion systems
    • H03M1/121Interleaved, i.e. using multiple converters or converter parts for one channel
    • H03M1/1215Interleaved, i.e. using multiple converters or converter parts for one channel using time-division multiplexing

Definitions

  • This application relates generally to linear combination of signals.
  • Linear combiners such as digital filters
  • RF sampling receivers convert an analog RF signal directly to a digital signal, thereby eliminating RF local oscillators (LO), mixers, gain stages and filters.
  • LO local oscillators
  • a wide range of applications use this type of receiver including 3G/4G base station receivers, software-defined radio (SDR) and high performance test equipment.
  • RF sampling typically uses an interleaved analog-to-digital converter (ADC).
  • ADC analog-to-digital converter
  • a device may use 4 ADCs sampling alternately at 750 million samples per second (MSPS) to realize a 3 billion (giga-) samples per second (GSPS) ADC. That is, while one ADC is latching an input, the other three ADCs are processing their inputs. Thus, the four ADCs process four inputs for each period and the combined throughput is 4 ⁇ 750 MSPS or 3 GSPS.
  • mismatch corrector can correct spurs caused by IL mismatches.
  • Examples of mismatch correctors can be found in co-owned U.S. Pat. Nos. 7,916,051 and 7,915,050, which are hereby fully incorporated herein by reference.
  • the mismatches are typically frequency dependent and need a linear corrector or filter of many coefficients or “taps.” For example, a 3 GSPS ADC using a 750 MSPS ADCs typically will use a filter of 32 taps for each component ADC.
  • an integrated circuit includes a linear combiner having an input for receiving a signal.
  • the linear combiner also has a plurality of operator circuits for applying weighting factors to the signal, in which a first operator in the plurality of operator circuits performs a first operation on the signal using a first sub-weight of one of the weighting factors to provide a first tile output and a second operator circuit in the plurality of operator circuits performs a second operation on the signal using a second sub-weight of the one of the weighting factors to provide a second tile output.
  • the linear combiner also has an adder having a first input coupled to receive the first tile output and the second tile outputs and providing a combined output.
  • FIG. 1 is a block diagram of a high throughput analog to digital converter (ADC).
  • ADC analog to digital converter
  • FIG. 2 is a schematic diagram of a linear correction circuit that corrects for mismatches in the response of interleaved ADCs.
  • FIG. 3 is a schematic diagram of a finite impulse response (FIR) filter.
  • FIG. 4 is a graph showing four example sets of weighting factors.
  • FIG. 5 is a graph of an example weighting factor configuration.
  • FIG. 6 is a block diagram of an example linear combiner.
  • FIG. 7 is a schematic diagram showing a data flow through a linear combiner.
  • FIG. 8 is a block diagram of an example ADC interleaving corrector.
  • FIG. 9 is a flowchart of an example method.
  • FIG. 10 is an example method for performing a step of the method of FIG. 9 .
  • Coupled may include connections made with intervening elements, and additional elements and various connections may exist between any elements that are “coupled.”
  • plurality as used herein means two or more.
  • FIG. 1 is a block diagram of a high throughput analog to digital converter (ADC) 100 .
  • ADC analog to digital converter
  • Differential inputs 101 feed buffers 102 and 104 .
  • Each of ADCs 106 , 108 , 110 and 112 has a throughput of 750 million samples per second (MSPS). Therefore, the combined throughput is 3 giga-samples per second (GSPS).
  • ADCs 106 , 108 , 110 and 112 operate under the control of clock divider 116 .
  • Differential clock inputs CLKP 118 and CLKM 120 drive clock divider 116 .
  • ADCs 106 , 108 , 110 and 112 sample the input signal serially, one at a time.
  • Buffers 102 and 104 insure that each of ADCs 106 , 108 , 110 and 112 has the appropriate input when necessary. That is, buffers 102 and 104 along with clock divider 116 cause ADCs 106 , 108 , 110 and 112 to provide an interleaved output signal with a combined sampling rate of 3 GSPS. Digital estimation and correction block 114 combines the outputs of ADCs 106 , 108 , 110 and 112 as a single output. The use of four ADCs is an example. The number of interleaved ADCs is only limited by practical considerations of implementation.
  • One ADC may have a gain of x at a frequency and the next ADC may have a gain of x*1.02 at that frequency. Even small mismatches create frequency spurs in the overall ADC output that can cause significant performance problems in downstream processing of that output.
  • FIG. 2 is a schematic diagram of an interleaving mismatch correction circuit 200 that corrects for mismatches in the response of interleaved ADCs, such as ADCs 106 , 108 , 110 and 112 ( FIG. 1 ).
  • Circuit 200 can be implemented in hardware or software.
  • digital estimation and correction block 114 FIG. 1 ) is an integrated circuit that includes circuit 200 implemented in hardware.
  • ADC output x(n) 201 is the combined, interleaved output of ADCs 106 , 108 , 110 and 112 ( FIG. 1 ).
  • Delay unit 202 and linear combiners 204 , 206 and 208 receive ADC output x(n) 201 .
  • One ADC for example ADC 106 ( FIG.
  • Delay unit 202 is a tapped delay line that delays this output to align it in time with the output of the other ADCs because of the delays caused by linear combiners 204 , 206 and 208 .
  • Linear combiners 204 , 206 and 208 are multi-tap finite impulse response (FIR) filters.
  • linear combiner 204 may provide correction for ADC 108 ( FIG. 1 )
  • linear combiner 206 may provide correction for ADC 110 ( FIG. 1 )
  • linear combiner 208 may provide correction for ADC 112 ( FIG. 1 ).
  • Switches 216 , 218 and 220 coordinate so that the output of linear combiners 204 , 206 and 208 arrive at subtraction unit 222 at the same time as the ADC output for the corresponding ADC.
  • the output of linear combiners 204 , 206 and 208 is a correction factor for the output of ADCs 108 , 110 and 112 ( FIG. 1 ), respectively.
  • the respective correction factor arrives at subtraction unit 222 at the same time as the output of the respective ADC and corrects for the mismatch between that ADC and the reference ADC.
  • FIG. 3 is a schematic diagram of a finite impulse response (FIR) filter 300 .
  • An FIR filter is one example of a linear combiner.
  • linear combiners 204 , 206 and 208 may be FIR filters.
  • Input 301 corresponds to the input to one of linear combiners 204 , 206 and 208 ( FIG. 2 ).
  • Operator circuits, such as delay unit 302 - 0 and multiplier 304 - 0 receive input 301 .
  • Delay unit 302 - 1 and multiplier 304 - 1 receive the output of delay unit 302 - 0 . This pattern repeats until only multiplier 304 - n - 1 receives the output of delay unit 302 - n - 2 .
  • the integer n is the number of weighting factors or taps in the filter.
  • Multipliers 304 - 0 through 304 - n - 1 multiply the respective inputs with taps 305 - 0 through 305 - n - 1 , respectively.
  • a tap is a number selected to provide the desired filter response according to FIR filter theory.
  • Adders 306 - 1 through 306 - n - 1 add the outputs of multipliers 304 - 0 through 304 - n - 1 to provide correction output 308 .
  • FIG. 4 is a graph showing the bit size (i.e., the bit width needed to design a filter) for four example sets of weighting factors or taps like taps 305 - 0 through 305 - n - 1 (h 0 through h n-1 ) ( FIG. 3 ).
  • the weighting factors are filter taps.
  • Filter 402 is for a high ADC mismatch with no delay correction.
  • Filter 404 is for a high ADC mismatch with delay correction.
  • Filter 406 is for a medium ADC mismatch with no delay correction.
  • Filter 408 is for a medium ADC mismatch with delay correction.
  • Graph 400 shows that each of the filter tap sets includes, in this example, 32 filter taps.
  • the vertical axis of graph 400 indicates the number of bits needed to represent the filter tap.
  • Graph 400 shows that the number of bits needed for various taps has a great variation from less than two to twelve.
  • Each one of the taps illustrated in graph 400 corresponds to a multiplier in FIR 300 ( FIG. 3 ).
  • a worst case bit width of 12-bits per tap may be used to implement the filters. In such a case, each multiplier multiplies a 12-bit tap with a 9-bit ADC input, and thus is a 12 ⁇ 9 multiplier.
  • FIG. 5 is a graph 500 of an example weight factor or tap configuration.
  • the taps shown in graph 500 are similar to the taps shown in graph 400 .
  • Each tap or weight is divided into sub-weights according to the number of bits in the tiles.
  • High tile 502 includes the most significant bits 9 - 11 of the taps.
  • Medium tile 504 includes bits 4 - 8 of the taps.
  • Low tile 506 includes bits 0 - 3 of the taps.
  • the tiles are not simply the respective bits.
  • Binary numbers are usually represented in complex configurations such as 2's complement to allow for simpler and/or faster circuitry to perform mathematical functions. With such complex binary number configurations, simply removing the medium and low bits from taps may separate those bits from the sign bit(s) and change the numeric value of those groups of bits.
  • the sub-weights in tiles 502 , 504 and 506 must be determined in a manner that preserves the overall value of the weight (tap).
  • the medium and low tile sub-weights may be the corresponding bits with an added sign bit to preserve their value.
  • a rounding procedure accounts for the sign while preserving the overall value of the weight without the need to add additional sign bits.
  • the weight h is the binary number 010100011001, which is expressed in 2's complement format. Converting the weight to sub-weights in this example uses the following scaled, rounding-based decomposition procedure.
  • Equation 1 the eight most significant bits of the weight h are removed to produce the low tile weight h L . This is expressed mathematically in Equation 1:
  • & represents the Boolean AND function and 0xF is the hexadecimal representation of the binary number 000000001111. That is, 0xF has zeros in the bit positions to be removed and ones in the bit positions to be preserved.
  • the weight h is truncated to a weight h HM including the high and medium bits and where the least significant bit of h HM is rounded. That is, if the most significant bit of h L is one, a one is added in the least significant bit position of h HM .
  • h is 010100011001
  • the bottom four bits are removed, which truncates to 01010001. Because the most significant bit of h L is 1, rounding adds a one in the least significant bit position to yield 01010010. This is expressed mathematically in Equation 2:
  • the number of bits rounded is four.
  • h L is 1001. In 2's complement notation, that is ⁇ 7. However, these bits represent 9 in weight h. To correct for this, a one in the least significant bit position of h HM (2 4 ) is added by rounding. That is, 16 is added to h HM . The added 16 compensates for the change in value of the h L because of the 2's complement format. That is, 16 added to negative 7 equals the original value of 9. Thus, the rounding operation preserves the original value without the need to add an additional sign bit to h L . If the leading bit of h L is zero, the original value of the low tile bits and the 2's complement representation are the same. Therefore, whether the most significant bit of h L is 0 or 1, the four bits of h L can be used as a 2's complement number without the need to add a sign bit or any other alteration.
  • Equation 3 the medium tile sub-weight h M is determined by removing the three most significant bits of h HM . This is expressed mathematically in Equation 3:
  • 0x1F is the hexadecimal representation of 31 or 00011111
  • the high tile sub-weight h H is determined by rounding h HM to the high tile bits.
  • the lower five bits of h HM are rounded off. This is expressed mathematically in Equation 4:
  • h HM is 01010010, which is truncated to 010.
  • the rounding of h H allows h M to be used as a 2's complement number without alteration (that is, no added sign bit is necessary).
  • x(n) is the input digital signal from the ADCs.
  • FIG. 6 is a block diagram of an example linear combiner 600 .
  • Linear combiner 600 may have all or a portion of its components in an integrated circuit or multiple integrated circuits in a hybrid package.
  • a processor such as a digital signal processor may implement all or a portion of the components of linear combiner 600 .
  • Linear combiner 600 performs a function like one of linear combiners 204 , 206 or 208 ( FIG. 2 ).
  • Dithered quantizer 602 receives ADC output x(n) 601 .
  • ADC output x(n) 601 may be, for example, 15 bits.
  • Dithered quantizer 602 quantizes ADC output x(n) 601 to a lower precision by truncating it to a lower number bits, for example, truncating the lower 6 bits of ADC output x(n) 601 . Therefore, the output of dithered quantizer 602 is the 9 most significant bits of ADC output x(n) 601 . Mathematics, simulations and/or experimentation determine the allowable level of truncation that avoids the addition of significant noise to the final output.
  • High tile combiner 610 is, in this example, a finite impulse response (FIR) filter like FIR 300 ( FIG. 3 ).
  • the taps that are applied to high tile combiner 610 are the sub-weights of high tiles 502 ( FIG. 5 ). Therefore, each multiplication in high tile combiner 610 is a nine-bit input times a three-bit high tile filter quantity.
  • up-shifter 611 shifts the output of high tile combiner 610 higher the number of bits in the corresponding the bit size of medium tile 504 ( FIG.
  • up-shifter 611 shifts the output of high tile combiner 610 eight bits.
  • Graph 500 shows that most of high tiles 502 ( FIG. 5 ) are zero. That is, the tap from which high tiles 502 ( FIG. 5 ) is derived has a value lower than 2 8 , in this example.
  • the multipliers of high tile combiner 610 like the multipliers in the FIR filter of high tile combiner 610 that correspond to multipliers 304 - 0 through 304 - n - 1 FIG. 3 ) have a tile input of zero
  • high tile combiner 610 provides a multiplier output of zero and blocks the clock signals driving that multiplier so that multiplier does not operate. Even multiplying by zero can consume considerable energy. By blocking the clock of the multipliers that are multiplying zero saves significant power with no impact on the quality of the filter output.
  • Dithered quantizer 604 quantizes ADC output x(n) 601 to a lower precision by truncating the lower bits of ADC output x(n) 601 by, for example, 9 bits, three bits more than dithered quantizer 602 .
  • the taps in medium tile 504 ( FIG. 5 ) represent the values of bits 5 - 8 of the full tap and feed medium tile combiner 612 .
  • the larger truncation by dithered quantizer 604 does not cause intolerable levels of noise as opposed to the smaller truncation of dithered quantizer 602 , because up-shifter 613 shifts the output of medium tile combiner 612 by five fewer bits.
  • Medium tile combiner 612 includes an FIR filter like FIR filter 300 ( FIG. 3 ). As with high tile combiner 610 , the combination of the tiled sub-weights and the truncated input of dithered quantizer 604 allows for smaller 5 ⁇ 6 multipliers in the FIR of medium tile combiner 612 .
  • the output of up-shifter 613 is a medium tile correction output that is added to the output of up-shifter 611 by adder 618 . As with high tile combiner 610 , for any tile that is zero, medium tile combiner 612 may, in some examples, provide a zero multiplier output and block the operation of that multiplier.
  • Multiplier 608 scales and multiplies ADC output x(n) 601 by a factor ⁇ .
  • Dithered quantizer 606 receives the output of multiplier 608 and provides the top three bits of the a adjusted ADC output x(n) 601 to low tile combiner 614 .
  • the a factor is a number less than one, for example, 0.75.
  • Dithered quantizer 606 quantizes ADC output x(n) 601 to a lower precision by truncating the lower bits of ADC output x(n) 601 by, for example, 12 bits, three bits more than dithered quantizer 604 .
  • the multiplication by a is done to ensure that the heavy truncation of the input does not cause saturation.
  • the sub-weights in low tile 506 represent the values of bits 1 - 4 of the full tap and feed low tile combiner 614 .
  • Low tile combiner 614 includes an FIR filter like FIR filter 300 ( FIG. 3 ).
  • FIR filter 300 FIG. 3
  • Multiplier 616 operates as a descaler and multiplies the output of low tile combiner 614 with the inverse of a to compensate for the initial multiplication by a and provide a low tile correction output.
  • Adder 620 adds the output of multiplier 616 to the output of adder 618 to provide a combined correction output.
  • the combined correction factor combines with the delayed ADC output x(n) 601 in a similar manner to one of combiners 204 , 206 or 208 to correct delayed ADC output x(n) 601 .
  • the combiners of FIG. 6 have 9 ⁇ 3 multipliers for the high tile (high tile combiner 610 ), 6 ⁇ 5 multipliers for medium tile (medium tile combiner 612 ) and 3 ⁇ 4 multipliers for low tile (low tile combiner 614 ).
  • FIG. 7 is a schematic diagram 700 showing a data flow through a linear combiner like linear combiner 600 ( FIG. 6 ).
  • dithered quantizer 602 ( FIG. 6 ) quantizes ADC output x(n) 701 to a lower precision of nine bits, for example by truncating the lower bits of ADC output x(n) 701 to truncated output 704 .
  • Multiplier 708 multiplies truncated output 704 by high tile sub-weight 706 .
  • dithered quantizer 604 ( FIG. 6 ) quantizes ADC output x(n) 701 to a lower precision of nine bits, for example by truncating the lower bits of ADC output x(n) 701 to truncated output 704 .
  • Multiplier 708 multiplies truncated output 704 by high tile sub-weight 706 .
  • dithered quantizer 604 ( FIG.
  • ADC output x(n) 701 quantizes ADC output x(n) 701 to a lower precision of six bits, for example, by truncating the lower bits of ADC output x(n) 701 to provide truncated output 710 .
  • Multiplier 714 multiplies truncated output 710 by medium tile sub-weight 712 .
  • multiplier 716 multiplies ADC output x(n) 701 by a.
  • Dithered quantizer 606 quantizes ADC output x(n) 701 to a lower precision of three bits, for example, by truncating the output of multiplier 716 to three bits to truncated output 718 .
  • Multiplier 722 multiplies truncated output 718 by low tile sub-weight 720 .
  • high tile sub-weight 706 may be 3 bits
  • medium tile sub-weight 712 may be 5 bits
  • low tile sub-weight 720 may be 4 bits.
  • Shifter 726 shifts the output of multiplier 708 to compensate the bit positions below high tile sub-weight 706 that are part of the full tap 734 .
  • Shifter 728 shifts the output of multiplier 714 to compensate for bit positions below medium tile sub-weight 712 that are part of the full tap 734 .
  • Adder 730 adds the outputs of shifters 726 and 728 .
  • Multiplier 724 multiplies the output of multiplier 722 by the inverse of a, and adder 732 adds the output of multiplier 724 to the output of adder 730 .
  • the output of adder 732 is the correction factor applied to the ADC output stream as further explained below.
  • FIG. 7 is a simplification for clarity.
  • Each of the high tile combiner 610 , medium tile combiner 612 and low tile combiner 614 ( FIG.
  • each of the high tile combiner 610 , medium tile combiner 612 and low tile combiner 614 includes the elements as shown in FIG. 3 .
  • FIG. 8 is a block diagram of an example ADC interleaving corrector 800 .
  • ADC interleaving corrector 800 may have all or a portion of its components in an integrated circuit or multiple integrated circuits in a hybrid package.
  • a processor such as a digital signal processor may implement all or a portion of the components of ADC interleaving corrector 800 .
  • ADC output x(n) 801 includes the output of four interleaved ADCs like ADCs 106 , 108 , 110 and 112 ( FIG. 1 ). As noted herein above, the output of one of the ADCs is a reference output.
  • this output arrives at subtractor 822 at time 4 p, where p is a sample index from the ADCs (ADCs 106 , 108 , 110 and 112 of FIG. 1 ).
  • p is a sample index from the ADCs (ADCs 106 , 108 , 110 and 112 of FIG. 1 ).
  • the output of the next ADC for example, ADC 108 ( FIG. 1 )
  • the output of the next ADC arrives at subtractor 822 .
  • switch 816 closes.
  • linear combiner 804 applies a correction factor to subtractor 822 to adjust the output of ADC 108 ( FIG. 1 ).
  • the output of the next ADC (for example, ADC 110 ( FIG. 1 )) arrives at subtractor 822 .
  • switch 818 closes.
  • linear combiner 806 applies a correction factor to subtractor 822 to adjust the output of ADC 110 ( FIG. 1 ).
  • the output of the next ADC for example, ADC 112 ( FIG. 1 ) arrives at subtractor 822 .
  • switch 820 closes.
  • linear combiner 808 applies a correction factor to subtractor 822 to adjust the output of ADC 112 ( FIG. 1 ). The cycle then repeats.
  • Linear combiners 804 , 806 and 808 include, in this example, three-tile combiners like linear combiner 600 ( FIG. 6 ).
  • Interleave (IL) mismatch estimator 832 estimates the mismatches between ADCs based on experimental data, on-chip estimation, simulations, and the frequency, amplitude and other characteristics of ADC output x(n) 801 .
  • Correction filter generator 834 generates filter characteristics (number of taps, tap amplitude, etc.) and provides this data to dynamic tile optimizer 830 .
  • Dynamic tile optimizer 830 generates sub-weights 824 (like sub-weights of high tiles 502 , medium tiles 504 and low tiles 506 ( FIG. 5 )), filter length 826 and clock/data gating 828 from the output of correction filter generator and provides that data to linear combiners 804 , 806 and 808 .
  • FIG. 9 is a flowchart of an example method 900 .
  • Step 902 provides filter values including at least two weights or taps.
  • FIG. 4 shows four filters 402 , 404 , 406 and 408 , where each filter includes thirty-two taps.
  • Step 904 divides the taps into at least sub-weights corresponding to two tiles.
  • FIG. 5 shows the weights of FIG. 4 divided into three tiles 502 , 504 and 506 .
  • Step 906 applies the sub-weights using a linear combiner for each tile to determine a correction factor output for a signal.
  • linear combiner 600 includes high tile combiner 610 , medium tile combiner 612 and low tile combiner 614 ( FIG.
  • Step 908 combines the correction factor outputs determined in step 906 to provide a combined correction factor output.
  • adders 618 and 620 combine the outputs of high tile combiner 610 as shifted by up-shifter 611 , medium tile combiner 612 as shifted by up-shifter 613 , and low tile combiner as descaled by multiplier 616 .
  • Step 910 corrects the signal using the combined correction factor output by adding or subtracting the correction factor as described regarding subtractor 822 ( FIG. 8 ).
  • FIG. 10 is an example method 1000 for performing step 906 of method 900 ( FIG. 9 ).
  • Step 1002 determines if the sub-weight of the current tap in the currently operating tile is zero. If not, step 1004 uses the sub-weight to determine a partial product. For example, the output of one of multipliers 304 - 0 through 304 - n - 1 ( FIG. 3 ) is a partial product. If the sub-weight for the current tap is zero, step 1006 sets the partial product to zero and disables the linear function (for example, one of multipliers 304 - 0 through 304 - n - 1 FIG. 3 ) to save power. For example, if one of the sub-weights in high tiles 502 ( FIG.
  • Step 1008 combines the partial product determined in either step 1004 or step 1006 with previous partial products.
  • Step 1010 determines if the current tap is the last tap. If not, the method loops back to step 1002 . If it is the last tap, step 1012 outputs the combined partial products as the linear correction factor for the tile.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Pure & Applied Mathematics (AREA)
  • Mathematical Optimization (AREA)
  • Mathematical Analysis (AREA)
  • Computational Mathematics (AREA)
  • Analogue/Digital Conversion (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

In accordance with an example, an integrated circuit includes a linear combiner having an input for receiving a signal. The linear combiner also has a plurality of operator circuits for applying weighting factors to the signal, in which a first operator circuit in the plurality of operator circuits performs a first operation on the signal using a first sub-weight of one of the weighting factors to provide a first tile output and a second operator circuit in the plurality of operator circuits performs a second operation on the signal using a second sub-weight of the one of the weighting factors to provide a second tile output. The linear combiner also has an adder having a first input coupled to receive the first tile output and the second tile outputs and providing a combined output.

Description

    CROSS-REFERENCE TO RELATED APPLICATION(S)
  • This continuation application claims priority to U.S. patent application Ser. No. 15/645,647, filed Jul. 10, 2017, which application claims priority to and the benefit of India Provisional Patent Application No. 201641024045, filed Jul. 14, 2016, both of which are hereby incorporated herein by reference.
  • TECHNICAL FIELD
  • This application relates generally to linear combination of signals.
  • BACKGROUND
  • Linear combiners, such as digital filters, have many uses in signal processing. One of those uses is with RF sampling receivers. RF sampling receivers convert an analog RF signal directly to a digital signal, thereby eliminating RF local oscillators (LO), mixers, gain stages and filters. A wide range of applications use this type of receiver including 3G/4G base station receivers, software-defined radio (SDR) and high performance test equipment.
  • RF sampling typically uses an interleaved analog-to-digital converter (ADC). For example, a device may use 4 ADCs sampling alternately at 750 million samples per second (MSPS) to realize a 3 billion (giga-) samples per second (GSPS) ADC. That is, while one ADC is latching an input, the other three ADCs are processing their inputs. Thus, the four ADCs process four inputs for each period and the combined throughput is 4×750 MSPS or 3 GSPS.
  • However, it is difficult to perfectly match ADCs. A typical mismatch is a difference in gain and phase at different frequencies. An interleaving (IL) mismatch corrector can correct spurs caused by IL mismatches. Examples of mismatch correctors can be found in co-owned U.S. Pat. Nos. 7,916,051 and 7,915,050, which are hereby fully incorporated herein by reference. The mismatches are typically frequency dependent and need a linear corrector or filter of many coefficients or “taps.” For example, a 3 GSPS ADC using a 750 MSPS ADCs typically will use a filter of 32 taps for each component ADC.
  • However, many applications for linear combiners, such as digital filters, must have very low power consumption. The large number of taps and the complex mathematical functions implemented by the combiners make this difficult to achieve.
  • SUMMARY
  • In accordance with an example, an integrated circuit includes a linear combiner having an input for receiving a signal. The linear combiner also has a plurality of operator circuits for applying weighting factors to the signal, in which a first operator in the plurality of operator circuits performs a first operation on the signal using a first sub-weight of one of the weighting factors to provide a first tile output and a second operator circuit in the plurality of operator circuits performs a second operation on the signal using a second sub-weight of the one of the weighting factors to provide a second tile output. The linear combiner also has an adder having a first input coupled to receive the first tile output and the second tile outputs and providing a combined output.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram of a high throughput analog to digital converter (ADC).
  • FIG. 2 is a schematic diagram of a linear correction circuit that corrects for mismatches in the response of interleaved ADCs.
  • FIG. 3 is a schematic diagram of a finite impulse response (FIR) filter.
  • FIG. 4 is a graph showing four example sets of weighting factors.
  • FIG. 5 is a graph of an example weighting factor configuration.
  • FIG. 6 is a block diagram of an example linear combiner.
  • FIG. 7 is a schematic diagram showing a data flow through a linear combiner.
  • FIG. 8 is a block diagram of an example ADC interleaving corrector.
  • FIG. 9 is a flowchart of an example method.
  • FIG. 10 is an example method for performing a step of the method of FIG. 9.
  • DETAILED DESCRIPTION
  • Corresponding numerals and symbols in the different figures generally refer to corresponding parts unless otherwise indicated. The figures are not necessarily drawn to scale.
  • The term “coupled” may include connections made with intervening elements, and additional elements and various connections may exist between any elements that are “coupled.” The term “plurality” as used herein means two or more.
  • FIG. 1 is a block diagram of a high throughput analog to digital converter (ADC) 100. Differential inputs 101 feed buffers 102 and 104. Each of ADCs 106, 108, 110 and 112 has a throughput of 750 million samples per second (MSPS). Therefore, the combined throughput is 3 giga-samples per second (GSPS). ADCs 106, 108, 110 and 112 operate under the control of clock divider 116. Differential clock inputs CLKP 118 and CLKM 120 drive clock divider 116. To provide 3 GSPS throughput, ADCs 106, 108, 110 and 112 sample the input signal serially, one at a time. Buffers 102 and 104 insure that each of ADCs 106, 108, 110 and 112 has the appropriate input when necessary. That is, buffers 102 and 104 along with clock divider 116 cause ADCs 106, 108, 110 and 112 to provide an interleaved output signal with a combined sampling rate of 3 GSPS. Digital estimation and correction block 114 combines the outputs of ADCs 106, 108, 110 and 112 as a single output. The use of four ADCs is an example. The number of interleaved ADCs is only limited by practical considerations of implementation.
  • However, it is very difficult to make four ADCs with the same response characteristics. One ADC may have a gain of x at a frequency and the next ADC may have a gain of x*1.02 at that frequency. Even small mismatches create frequency spurs in the overall ADC output that can cause significant performance problems in downstream processing of that output.
  • FIG. 2 is a schematic diagram of an interleaving mismatch correction circuit 200 that corrects for mismatches in the response of interleaved ADCs, such as ADCs 106, 108, 110 and 112 (FIG. 1). Circuit 200 can be implemented in hardware or software. In an example, digital estimation and correction block 114 (FIG. 1) is an integrated circuit that includes circuit 200 implemented in hardware. ADC output x(n) 201 is the combined, interleaved output of ADCs 106, 108, 110 and 112 (FIG. 1). Delay unit 202 and linear combiners 204, 206 and 208 receive ADC output x(n) 201. One ADC, for example ADC 106 (FIG. 1), is a reference ADC. The output of this ADC passes through circuit 200 uncorrected. Delay unit 202 is a tapped delay line that delays this output to align it in time with the output of the other ADCs because of the delays caused by linear combiners 204, 206 and 208.
  • Linear combiners 204, 206 and 208, in this example, are multi-tap finite impulse response (FIR) filters. For example, linear combiner 204 may provide correction for ADC 108 (FIG. 1), linear combiner 206 may provide correction for ADC 110 (FIG. 1), and linear combiner 208 may provide correction for ADC 112 (FIG. 1).
  • Switches 216, 218 and 220 coordinate so that the output of linear combiners 204, 206 and 208 arrive at subtraction unit 222 at the same time as the ADC output for the corresponding ADC. The output of linear combiners 204, 206 and 208 is a correction factor for the output of ADCs 108, 110 and 112 (FIG. 1), respectively. The respective correction factor arrives at subtraction unit 222 at the same time as the output of the respective ADC and corrects for the mismatch between that ADC and the reference ADC.
  • FIG. 3 is a schematic diagram of a finite impulse response (FIR) filter 300. An FIR filter is one example of a linear combiner. As noted hereinabove, linear combiners 204, 206 and 208 (FIG. 2) may be FIR filters. Input 301 corresponds to the input to one of linear combiners 204, 206 and 208 (FIG. 2). Operator circuits, such as delay unit 302-0 and multiplier 304-0 receive input 301. Delay unit 302-1 and multiplier 304-1 receive the output of delay unit 302-0. This pattern repeats until only multiplier 304-n-1 receives the output of delay unit 302-n-2. The integer n is the number of weighting factors or taps in the filter. Multipliers 304-0 through 304-n-1 multiply the respective inputs with taps 305-0 through 305-n-1, respectively. A tap is a number selected to provide the desired filter response according to FIR filter theory. Adders 306-1 through 306-n-1 add the outputs of multipliers 304-0 through 304-n-1 to provide correction output 308.
  • FIG. 4 is a graph showing the bit size (i.e., the bit width needed to design a filter) for four example sets of weighting factors or taps like taps 305-0 through 305-n-1 (h0 through hn-1) (FIG. 3). In this example, the weighting factors are filter taps. Filter 402 is for a high ADC mismatch with no delay correction. Filter 404 is for a high ADC mismatch with delay correction. Filter 406 is for a medium ADC mismatch with no delay correction. Filter 408 is for a medium ADC mismatch with delay correction. Graph 400 shows that each of the filter tap sets includes, in this example, 32 filter taps. The vertical axis of graph 400 indicates the number of bits needed to represent the filter tap. Graph 400 shows that the number of bits needed for various taps has a great variation from less than two to twelve. Each one of the taps illustrated in graph 400 corresponds to a multiplier in FIR 300 (FIG. 3). Each correction circuit 200 (FIG. 2) includes three filters, such as linear combiners 204, 206 and 208 (FIG. 2). Therefore, the described examples include 3*32=96 multipliers. A worst case bit width of 12-bits per tap may be used to implement the filters. In such a case, each multiplier multiplies a 12-bit tap with a 9-bit ADC input, and thus is a 12×9 multiplier. Each of these multipliers performs a multiplication every 1/750 MHz=1.34 nS. This consumes a very large amount power.
  • FIG. 5 is a graph 500 of an example weight factor or tap configuration. The taps shown in graph 500 are similar to the taps shown in graph 400. Each tap or weight is divided into sub-weights according to the number of bits in the tiles. High tile 502 includes the most significant bits 9-11 of the taps. Medium tile 504 includes bits 4-8 of the taps. Low tile 506 includes bits 0-3 of the taps. The tiles are not simply the respective bits. Binary numbers are usually represented in complex configurations such as 2's complement to allow for simpler and/or faster circuitry to perform mathematical functions. With such complex binary number configurations, simply removing the medium and low bits from taps may separate those bits from the sign bit(s) and change the numeric value of those groups of bits.
  • Therefore, the sub-weights in tiles 502, 504 and 506 must be determined in a manner that preserves the overall value of the weight (tap). In one example, the medium and low tile sub-weights may be the corresponding bits with an added sign bit to preserve their value. In another example, a rounding procedure accounts for the sign while preserving the overall value of the weight without the need to add additional sign bits. To explain this example, assume that the weight h is the binary number 010100011001, which is expressed in 2's complement format. Converting the weight to sub-weights in this example uses the following scaled, rounding-based decomposition procedure.
  • First, the eight most significant bits of the weight h are removed to produce the low tile weight hL. This is expressed mathematically in Equation 1:

  • h L =h&0xF  (1)
  • Where, & represents the Boolean AND function and 0xF is the hexadecimal representation of the binary number 000000001111. That is, 0xF has zeros in the bit positions to be removed and ones in the bit positions to be preserved.
  • Second, the weight h is truncated to a weight hHM including the high and medium bits and where the least significant bit of hHM is rounded. That is, if the most significant bit of hL is one, a one is added in the least significant bit position of hHM. Using the above example weight, h is 010100011001, the bottom four bits are removed, which truncates to 01010001. Because the most significant bit of hL is 1, rounding adds a one in the least significant bit position to yield 01010010. This is expressed mathematically in Equation 2:

  • h HM=round(h,4)  (2)
  • In this case, the number of bits rounded is four.
  • In this example, hL is 1001. In 2's complement notation, that is −7. However, these bits represent 9 in weight h. To correct for this, a one in the least significant bit position of hHM (24) is added by rounding. That is, 16 is added to hHM. The added 16 compensates for the change in value of the hL because of the 2's complement format. That is, 16 added to negative 7 equals the original value of 9. Thus, the rounding operation preserves the original value without the need to add an additional sign bit to hL. If the leading bit of hL is zero, the original value of the low tile bits and the 2's complement representation are the same. Therefore, whether the most significant bit of hL is 0 or 1, the four bits of hL can be used as a 2's complement number without the need to add a sign bit or any other alteration.
  • Third, the medium tile sub-weight hM is determined by removing the three most significant bits of hHM. This is expressed mathematically in Equation 3:

  • h M =h HM&0x1F  (3)
  • Where 0x1F is the hexadecimal representation of 31 or 00011111
  • Fourth, the high tile sub-weight hH is determined by rounding hHM to the high tile bits. In this example, the lower five bits of hHM are rounded off. This is expressed mathematically in Equation 4:

  • h H=rounded(h HM,5)  (4)
  • In the above example, hHM is 01010010, which is truncated to 010. The most significant bit of hM is one, so a one is added in the least significant bit position of hH to yield hH=011. As with the low tile sub-weight, the rounding of hH allows hM to be used as a 2's complement number without alteration (that is, no added sign bit is necessary).
  • These numbers added together provide the correct weight or tap. This provides the correct result because of the distributive property of linear functions. In this case, this can be expressed as Equation 5 and 6:

  • h=(h H*2(b M +b L ) +h M*2(b L ) +h L)  (5)
  • Where bM is the number of bits in hM and bL is the number of bits in hL. Therefore,

  • hx(n)=h H*2(b M +b L ) +h M*2(b L ) +h L)x(n)=(h H*2(b M +b L ))x(n)+(h M*2(b L ))x(n)+h L x(n)  (6)
  • Where x(n) is the input digital signal from the ADCs.
  • FIG. 6 is a block diagram of an example linear combiner 600. Linear combiner 600 may have all or a portion of its components in an integrated circuit or multiple integrated circuits in a hybrid package. In addition, a processor such as a digital signal processor may implement all or a portion of the components of linear combiner 600. Linear combiner 600 performs a function like one of linear combiners 204, 206 or 208 (FIG. 2). Dithered quantizer 602 receives ADC output x(n) 601. As noted hereinabove regarding FIG. 2, ADC output x(n) 601 may be, for example, 15 bits. Dithered quantizer 602 quantizes ADC output x(n) 601 to a lower precision by truncating it to a lower number bits, for example, truncating the lower 6 bits of ADC output x(n) 601. Therefore, the output of dithered quantizer 602 is the 9 most significant bits of ADC output x(n) 601. Mathematics, simulations and/or experimentation determine the allowable level of truncation that avoids the addition of significant noise to the final output.
  • High tile combiner 610 is, in this example, a finite impulse response (FIR) filter like FIR 300 (FIG. 3). However, the taps that are applied to high tile combiner 610 are the sub-weights of high tiles 502 (FIG. 5). Therefore, each multiplication in high tile combiner 610 is a nine-bit input times a three-bit high tile filter quantity. The multipliers 304-1 through 304-1 (FIG. 3) are 9-bit (input)×12 (coefficient) multipliers whose complexity is proportional to 9×12=108. Finally, up-shifter 611 shifts the output of high tile combiner 610 higher the number of bits in the corresponding the bit size of medium tile 504 (FIG. 5) and low tile 506 (FIG. 5) to provide a high tile correction output. In this example, the taps of high tile 502 (FIG. 5) implicitly include eight zero bits. Therefore, up-shifter 611 shifts the output of high tile combiner 610 eight bits.
  • Graph 500 (FIG. 5) shows that most of high tiles 502 (FIG. 5) are zero. That is, the tap from which high tiles 502 (FIG. 5) is derived has a value lower than 28, in this example. In some examples, when the multipliers of high tile combiner 610 (like the multipliers in the FIR filter of high tile combiner 610 that correspond to multipliers 304-0 through 304-n-1 FIG. 3) have a tile input of zero, high tile combiner 610 provides a multiplier output of zero and blocks the clock signals driving that multiplier so that multiplier does not operate. Even multiplying by zero can consume considerable energy. By blocking the clock of the multipliers that are multiplying zero saves significant power with no impact on the quality of the filter output.
  • Dithered quantizer 604 quantizes ADC output x(n) 601 to a lower precision by truncating the lower bits of ADC output x(n) 601 by, for example, 9 bits, three bits more than dithered quantizer 602. The taps in medium tile 504 (FIG. 5) represent the values of bits 5-8 of the full tap and feed medium tile combiner 612. The larger truncation by dithered quantizer 604 does not cause intolerable levels of noise as opposed to the smaller truncation of dithered quantizer 602, because up-shifter 613 shifts the output of medium tile combiner 612 by five fewer bits. Therefore, the output of up-shifter 613 is a smaller number and less significant in the final outcome. Medium tile combiner 612 includes an FIR filter like FIR filter 300 (FIG. 3). As with high tile combiner 610, the combination of the tiled sub-weights and the truncated input of dithered quantizer 604 allows for smaller 5×6 multipliers in the FIR of medium tile combiner 612. The output of up-shifter 613 is a medium tile correction output that is added to the output of up-shifter 611 by adder 618. As with high tile combiner 610, for any tile that is zero, medium tile combiner 612 may, in some examples, provide a zero multiplier output and block the operation of that multiplier.
  • Multiplier 608 scales and multiplies ADC output x(n) 601 by a factor α. Dithered quantizer 606 receives the output of multiplier 608 and provides the top three bits of the a adjusted ADC output x(n) 601 to low tile combiner 614. The a factor is a number less than one, for example, 0.75. Dithered quantizer 606 quantizes ADC output x(n) 601 to a lower precision by truncating the lower bits of ADC output x(n) 601 by, for example, 12 bits, three bits more than dithered quantizer 604. The multiplication by a is done to ensure that the heavy truncation of the input does not cause saturation. For example, if the input is 0.9 of the full scale of the input, quantizing such an input to only the 3 most significant bits results in saturation of the input. Due to this saturation, a spur arises at the output. To avoid such a spur, the input is scaled. In this example, multiplying 0.9 by 0.75 makes the input small enough so as to not be saturated. The sub-weights in low tile 506 (FIG. 5) represent the values of bits 1-4 of the full tap and feed low tile combiner 614. As with the medium tile branch, the larger truncation by dithered quantizer 606 does not cause intolerable levels of noise as opposed to the smaller truncation of dithered quantizers 602 and 604, because the output of low tile combiner 614 is not up-shifted. Therefore, the output of low tile combiner 614 is a smaller number and less significant in the final sum. Low tile combiner 614 includes an FIR filter like FIR filter 300 (FIG. 3). As with high tile combiner 610 and medium tile combiner 612, the combination of the tiled taps and the truncated input of dithered quantizer 604 allows for smaller 4×4 multipliers in the FIR of low tile combiner 614. Multiplier 616 operates as a descaler and multiplies the output of low tile combiner 614 with the inverse of a to compensate for the initial multiplication by a and provide a low tile correction output.
  • Adder 620 adds the output of multiplier 616 to the output of adder 618 to provide a combined correction output. The combined correction factor combines with the delayed ADC output x(n) 601 in a similar manner to one of combiners 204, 206 or 208 to correct delayed ADC output x(n) 601. The combiners of FIG. 6 have 9×3 multipliers for the high tile (high tile combiner 610), 6×5 multipliers for medium tile (medium tile combiner 612) and 3×4 multipliers for low tile (low tile combiner 614). Thus, the overall complexity is 9×3+6×5+3×4=27+30+12=69, which is about 35% lower in complexity than the original corrector (69 compared with 108).
  • FIG. 7 is a schematic diagram 700 showing a data flow through a linear combiner like linear combiner 600 (FIG. 6). For a high tile flow, dithered quantizer 602 (FIG. 6) quantizes ADC output x(n) 701 to a lower precision of nine bits, for example by truncating the lower bits of ADC output x(n) 701 to truncated output 704. Multiplier 708 multiplies truncated output 704 by high tile sub-weight 706. For the medium tile flow, dithered quantizer 604 (FIG. 6) quantizes ADC output x(n) 701 to a lower precision of six bits, for example, by truncating the lower bits of ADC output x(n) 701 to provide truncated output 710. Multiplier 714 multiplies truncated output 710 by medium tile sub-weight 712. For the low tile flow, multiplier 716 multiplies ADC output x(n) 701 by a. Dithered quantizer 606 (FIG. 6) quantizes ADC output x(n) 701 to a lower precision of three bits, for example, by truncating the output of multiplier 716 to three bits to truncated output 718. Multiplier 722 multiplies truncated output 718 by low tile sub-weight 720. In some examples, high tile sub-weight 706 may be 3 bits, medium tile sub-weight 712 may be 5 bits, and low tile sub-weight 720 may be 4 bits.
  • Shifter 726 shifts the output of multiplier 708 to compensate the bit positions below high tile sub-weight 706 that are part of the full tap 734. Shifter 728 shifts the output of multiplier 714 to compensate for bit positions below medium tile sub-weight 712 that are part of the full tap 734. Adder 730 adds the outputs of shifters 726 and 728. Multiplier 724 multiplies the output of multiplier 722 by the inverse of a, and adder 732 adds the output of multiplier 724 to the output of adder 730. The output of adder 732 is the correction factor applied to the ADC output stream as further explained below.
  • FIG. 7 is a simplification for clarity. In an actual example using an FIR filter, linear combiner 600 (FIG. 6) applies, as in the example of graph 500 (FIG. 5), thirty-two taps 734 to thirty-two multipliers for each of multipliers 708, 714 and 722 in the configuration of, for example, multipliers 304-0 through 304-n-1, where n=32. That is, each of multipliers 708, 714 and 722 represent thirty-two multipliers (or a smaller number of multipliers used repeatedly to provide thirty-two multiplications). Each of the high tile combiner 610, medium tile combiner 612 and low tile combiner 614 (FIG. 6) applies the tiles of taps like taps 305-0 through 305-n-1 (h0 through hn-1). FIG. 7 does not show delay units 302-0 through 302-n-2 and adders 306-1 through 306-n-1 (FIG. 3). However, in the example configuration, each of the high tile combiner 610, medium tile combiner 612 and low tile combiner 614 (FIG. 6) includes the elements as shown in FIG. 3.
  • FIG. 8 is a block diagram of an example ADC interleaving corrector 800. ADC interleaving corrector 800 may have all or a portion of its components in an integrated circuit or multiple integrated circuits in a hybrid package. In addition, a processor, such as a digital signal processor may implement all or a portion of the components of ADC interleaving corrector 800. ADC output x(n) 801 includes the output of four interleaved ADCs like ADCs 106, 108, 110 and 112 (FIG. 1). As noted herein above, the output of one of the ADCs is a reference output. After the delay of delay unit 802, this output arrives at subtractor 822 at time 4 p, where p is a sample index from the ADCs ( ADCs 106, 108, 110 and 112 of FIG. 1). At 4 p+1, the output of the next ADC (for example, ADC 108 (FIG. 1)) arrives at subtractor 822. At 4 p+1, switch 816 closes. Thus, linear combiner 804 applies a correction factor to subtractor 822 to adjust the output of ADC 108 (FIG. 1). At 4 p+2, the output of the next ADC (for example, ADC 110 (FIG. 1)) arrives at subtractor 822. At 4 p+2, switch 818 closes. Thus, linear combiner 806 applies a correction factor to subtractor 822 to adjust the output of ADC 110 (FIG. 1). At 4 p+3, the output of the next ADC (for example, ADC 112 (FIG. 1)) arrives at subtractor 822. At 4 p+3, switch 820 closes. Thus, linear combiner 808 applies a correction factor to subtractor 822 to adjust the output of ADC 112 (FIG. 1). The cycle then repeats.
  • Linear combiners 804, 806 and 808 include, in this example, three-tile combiners like linear combiner 600 (FIG. 6). Interleave (IL) mismatch estimator 832 estimates the mismatches between ADCs based on experimental data, on-chip estimation, simulations, and the frequency, amplitude and other characteristics of ADC output x(n) 801. Correction filter generator 834 generates filter characteristics (number of taps, tap amplitude, etc.) and provides this data to dynamic tile optimizer 830. Dynamic tile optimizer 830 generates sub-weights 824 (like sub-weights of high tiles 502, medium tiles 504 and low tiles 506 (FIG. 5)), filter length 826 and clock/data gating 828 from the output of correction filter generator and provides that data to linear combiners 804, 806 and 808.
  • FIG. 9 is a flowchart of an example method 900. Step 902 provides filter values including at least two weights or taps. For example, FIG. 4 shows four filters 402, 404, 406 and 408, where each filter includes thirty-two taps. Step 904 divides the taps into at least sub-weights corresponding to two tiles. For example, FIG. 5 shows the weights of FIG. 4 divided into three tiles 502, 504 and 506. Step 906 applies the sub-weights using a linear combiner for each tile to determine a correction factor output for a signal. For example, linear combiner 600 includes high tile combiner 610, medium tile combiner 612 and low tile combiner 614 (FIG. 6) to apply the sub-weights of high tile 502, medium tile 504 and low tile 506 (FIG. 5), respectively, to determine a correction factor output for each tile. Step 908 combines the correction factor outputs determined in step 906 to provide a combined correction factor output. For example, adders 618 and 620 combine the outputs of high tile combiner 610 as shifted by up-shifter 611, medium tile combiner 612 as shifted by up-shifter 613, and low tile combiner as descaled by multiplier 616. Step 910 corrects the signal using the combined correction factor output by adding or subtracting the correction factor as described regarding subtractor 822 (FIG. 8).
  • FIG. 10 is an example method 1000 for performing step 906 of method 900 (FIG. 9). Step 1002 determines if the sub-weight of the current tap in the currently operating tile is zero. If not, step 1004 uses the sub-weight to determine a partial product. For example, the output of one of multipliers 304-0 through 304-n-1 (FIG. 3) is a partial product. If the sub-weight for the current tap is zero, step 1006 sets the partial product to zero and disables the linear function (for example, one of multipliers 304-0 through 304-n-1 FIG. 3) to save power. For example, if one of the sub-weights in high tiles 502 (FIG. 5) is zero, the corresponding one of multipliers 304-0 through 304-n-1 (FIG. 3) is disabled to save power. If all of the sub-weights in a tile are zero, then all of the multipliers for that tile are disabled. Step 1008 combines the partial product determined in either step 1004 or step 1006 with previous partial products. Step 1010 determines if the current tap is the last tap. If not, the method loops back to step 1002. If it is the last tap, step 1012 outputs the combined partial products as the linear correction factor for the tile.
  • Modifications are possible in the described examples, and other examples are possible, within the scope of the claims. For example, although examples described herein employ finite impulse response filters, other examples may use other types of filters or other types of linear combiners.

Claims (10)

What is claimed is:
1. An interleaved analog-to-digital converter (ADC) comprising:
a plurality of buffers;
a plurality of analog-to-digital converters (ADC) coupled to the plurality of ADCs;
a linear combiner coupled to the plurality of ADCs; and
a clock divider, the clock divider coupled to a clock signal and the plurality of ADCs; wherein the clock divider causes the plurality of ADCs to provide an interleaved output signal to the linear combiner.
2. The interleaved ADC of claim 1 wherein the linear combiner comprises:
an input operable to receiving the interleaved output signal;
a plurality of operator circuits operable to apply weighting factors to the interleaved output signal, in which a first operator circuit in the plurality of operator circuits performs a first operation on the interleaved output signal using a first sub-weight of one of the weighting factors to provide a first tile output and a second operator circuit in the plurality of operator circuits performs a second operation on the interleaved output signal using a second sub-weight of the one of the weighting factors to provide a second tile output;
an adder having a first input coupled to receive the first tile output and the second tile output and providing a combined output; and
a scaler coupled between the input and the second operator circuit and a descaler coupled to an output of the second operator circuit.
3. The interleaved ADC of claim 2 in which the first sub-weight and second sub-weight are computed from bits of the one of the weighting factors.
4. The interleaved ADC of claim 2 in which the operator circuits are multipliers.
5. The interleaved ADC of claim 2 in which the first tile output is shifted upwards by a number of bits corresponding to bits in the second sub-weight.
6. The interleaved ADC of claim 2 in which the linear combiner is a filter.
7. The interleaved ADC of claim 2 in which the first operator circuit is disabled when the first sub-weight is zero.
8. The interleaved ADC of claim 21 in which the one of the weighting factors is in 2's complement format and the second sub-weight is a first number of least significant bits and the first sub-weight is a second number of bits beginning with a next most significant bit after the first number of least significant bits that is rounded depending on a value of a most significant bit of the first number of least significant bits.
9. The interleaved ADC of claim 2 in which the plurality of operator circuits includes a third operator circuit in the plurality of operator circuits that performs a third operation on the signal using a third sub-weight of the one of the weighting factors.
10. The interleaved ADC of claim 2 in which the signal is quantized to a lower precision for the first operation on the signal.
US16/299,299 2016-07-14 2019-03-12 Methods and apparatus for efficient linear combiner Abandoned US20190214972A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/299,299 US20190214972A1 (en) 2016-07-14 2019-03-12 Methods and apparatus for efficient linear combiner

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
IN201641024045 2016-07-14
IN201641024045 2016-07-14
US15/645,647 US10277202B2 (en) 2016-07-14 2017-07-10 Methods and apparatus for efficient linear combiner
US16/299,299 US20190214972A1 (en) 2016-07-14 2019-03-12 Methods and apparatus for efficient linear combiner

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US15/645,647 Continuation US10277202B2 (en) 2016-07-14 2017-07-10 Methods and apparatus for efficient linear combiner

Publications (1)

Publication Number Publication Date
US20190214972A1 true US20190214972A1 (en) 2019-07-11

Family

ID=60940217

Family Applications (2)

Application Number Title Priority Date Filing Date
US15/645,647 Active US10277202B2 (en) 2016-07-14 2017-07-10 Methods and apparatus for efficient linear combiner
US16/299,299 Abandoned US20190214972A1 (en) 2016-07-14 2019-03-12 Methods and apparatus for efficient linear combiner

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US15/645,647 Active US10277202B2 (en) 2016-07-14 2017-07-10 Methods and apparatus for efficient linear combiner

Country Status (1)

Country Link
US (2) US10277202B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112633486A (en) * 2019-09-24 2021-04-09 旺宏电子股份有限公司 Data sensing device and data sensing method thereof

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20200065676A1 (en) * 2018-08-22 2020-02-27 National Tsing Hua University Neural network method, system, and computer program product with inference-time bitwidth flexibility
CN113672860B (en) * 2021-08-25 2023-05-12 恒烁半导体(合肥)股份有限公司 Positive and negative number compatible in-memory operation method, multiplication and addition operation device and application thereof

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030174079A1 (en) * 2002-03-14 2003-09-18 Nec Usa, Inc. Feed-forward DC-offset canceller for direct conversion receiver
US20060256216A1 (en) * 2005-04-14 2006-11-16 Samsung Electronics Co., Ltd. Downconverter and upconverter
US20090271005A1 (en) * 2008-04-25 2009-10-29 Tannoy Limited Control system
US20100297975A1 (en) * 2006-06-27 2010-11-25 Fraunhofer-Gesellschaft Zur Foerderung Der Angewandten Forschung E.V. Signal processor and method for processing a receiving signal
US9628162B1 (en) * 2016-09-21 2017-04-18 The United States Of America As Represented By Secretary Of The Navy Techniques and methods for aliasing digital beamformers for reduced computational loads

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4615026A (en) * 1984-01-20 1986-09-30 Rca Corporation Digital FIR filters with enhanced tap weight resolution
JPH0435213A (en) * 1990-05-28 1992-02-06 Hitachi Ltd filter circuit
US6523055B1 (en) * 1999-01-20 2003-02-18 Lsi Logic Corporation Circuit and method for multiplying and accumulating the sum of two products in a single cycle
US7916051B1 (en) 2009-10-02 2011-03-29 Texas Instuments Incorporated Bandwidth mismatch estimation for time interleaved ADCs
US7916050B1 (en) 2009-10-15 2011-03-29 Texas Instruments Incorporated Time-interleaved-dual channel ADC with mismatch compensation

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030174079A1 (en) * 2002-03-14 2003-09-18 Nec Usa, Inc. Feed-forward DC-offset canceller for direct conversion receiver
US20060256216A1 (en) * 2005-04-14 2006-11-16 Samsung Electronics Co., Ltd. Downconverter and upconverter
US20100297975A1 (en) * 2006-06-27 2010-11-25 Fraunhofer-Gesellschaft Zur Foerderung Der Angewandten Forschung E.V. Signal processor and method for processing a receiving signal
US20090271005A1 (en) * 2008-04-25 2009-10-29 Tannoy Limited Control system
US9628162B1 (en) * 2016-09-21 2017-04-18 The United States Of America As Represented By Secretary Of The Navy Techniques and methods for aliasing digital beamformers for reduced computational loads

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112633486A (en) * 2019-09-24 2021-04-09 旺宏电子股份有限公司 Data sensing device and data sensing method thereof

Also Published As

Publication number Publication date
US20180019732A1 (en) 2018-01-18
US10277202B2 (en) 2019-04-30

Similar Documents

Publication Publication Date Title
US10555256B2 (en) Re-sampling with reduced power consumption and complexity
US5504455A (en) Efficient digital quadrature demodulator
US6639537B1 (en) Highly linear analog-to-digital conversion system and method thereof
JP5345242B2 (en) Sigma delta modulator with shortening and its application
US8410843B2 (en) Polyphase nonlinear digital predistortion
US20120121039A1 (en) Digital fast cordic for envelope tracking generation
US20190214972A1 (en) Methods and apparatus for efficient linear combiner
US10536302B1 (en) Beamspace nonlinear equalization for spur reduction
US11029919B2 (en) Internally truncated multiplier
US8660820B2 (en) Distortion cancellation using adaptive linearization
US7557619B1 (en) Digital frequency synthesis
US7592942B2 (en) Circuit and method for A/D conversion processing and demodulation device
Langlois et al. Hardware optimized direct digital frequency synthesizer architecture with 60 dBc spectral purity
US20160218733A1 (en) Processing system with encoding for processing multiple analog signals
US9632753B2 (en) Spectral shaping of pseudorandom binary sequence
KR20060014028A (en) Bi-Quad Digital Filters Configured with Bit Binary Rate Multipliers
US9923737B2 (en) Analog-digital compatible re-sampling
US12294399B2 (en) Method and apparatus for cancelling front-end distortion
WO2013099176A1 (en) Dem circuit, delta sigma modulator, d/a converter and wireless communication device
KR20010089746A (en) System and methods for multimode operation of a digital filter with shared resources
JP6512092B2 (en) Frequency characteristic correction circuit
Ming et al. Wideband Sample Rate Converter Using Cascaded Parallel-serial Structure for Synthetic Instrumentation
Piché et al. High Quality and Low Latency Interpolation Filters for FPGA-Based Audio Digital-to-Analog Converters
Avinash et al. Design of digital down converter using computation sharing multiplier architecture
Ashrafi A quasi-linear interpolation method to develop a direct digital frequency synthesizer with VLSI implementation

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION