I. Field
The present disclosure relates generally to electronics circuits, and more specifically to techniques for dynamically selecting circuit elements.
II. Background
Digital-to-analog converters (DACs) are widely used for various applications such as audio, video, data conversion, etc. A DAC receives digital input data and provides an analog output signal. The performance of the DAC may be quantified by various dynamic specifications such as total harmonic distortion (THD), spurious free dynamic range (SFDR), signal-to-noise ratio (SNR), etc.
An N-bit DAC may be implemented with N binary weighted circuit elements, where a circuit element may be a current source, a capacitor, a resistor, etc. With binary weighting, the smallest circuit element has a size of one unit, the next smallest circuit element has a size of two units, and so on, and the largest circuit element has a size of 2N-1 units. In each sample period, zero or more of the N circuit elements may be selected by a digital input data value and used to generate an analog output value for that sample period. The performance of the DAC is dependent on the accuracy of the sizes of the N binary weighted circuit elements. Since the size of the largest circuit element is 2N-1 times the size of the smallest circuit element, it may be difficult to accurately match these circuit elements. Consequently, the performance of the binary-weighted DAC may be relatively poor.
An N-bit DAC may also be implemented with 2N−1 circuit elements of equal size. In each sample period, a digital input data value of x may select x circuit elements to generate an analog output value for that sample period. Since all of the circuit elements have the same size, it may be easier to match these circuit elements. Nevertheless, there may be limitations on how closely the 2N−1 circuit elements can be matched. Hence, some mismatches typically exist between these circuit elements. To improve performance in the presence of the mismatches, the circuit elements may be selected in a manner such that errors due to the mismatches may be shaped and pushed out of band.
There is therefore a need in the art for techniques to dynamically select circuit elements in order to mitigate deleterious effects due to circuit element mismatches.
Techniques for dynamically selecting circuit elements in order to mitigate deleterious effects due to circuit element mismatches are described herein. According to an aspect, an apparatus includes first, second, and third circuits. The first circuit receives input data and provides a plurality of first signals that is asserted based on the input data. The first circuit may perform thermometer decoding on the input data and assert a number of first signals based on the input data. The second circuit receives the plurality of first signals and provides a plurality of second signals used to select a plurality of circuit elements, e.g., current sources, capacitors, resistors, etc. The third circuit generates a control for the second circuit, and the second circuit maps the plurality of first signals to the plurality of second signals based on this control.
In one design, the second circuit includes a plurality of multiplexers and a control circuit. Each multiplexer receives the plurality of first signals in a different order and provides one of the plurality of second signals. The plurality of multiplexers provide the plurality of first signals, circularly rotated by an amount determined by the control, as the plurality of second signals. The control circuit accumulates control data with the current value of the control to obtain a new value of the control. The control data may be the input data (for data weighted averaging), pseudo-random data, a fixed non-zero value, a value of zero, etc.
Various aspects and features of the disclosure are described in further detail below.
The dynamic element selection techniques described herein may be used for various circuits such as DACs, sigma-delta (ΣΔ) DACs, analog-to-digital converters (ADCs), ΣΔ ADCs, filters, etc. For clarity, the techniques are described below for DACs.
Output circuit 120 includes K circuit elements 122a through 122k that receive the K select signals Sel0 through SelK-1, respectively. Each circuit element 122 may comprise a current source, a switch, a capacitor, a resistor, etc., or any combination thereof. Each circuit element 122 may be enabled when its select signal is asserted and disabled when its select signal is de-asserted. Each circuit element 122, when enabled, provides its output to a summer 124. Summer 124 sums the output of all K circuit elements 122a through 122k and provides an analog output signal.
Decoder 110 may assert the K select signals in a systematic/static manner based on the input data, as described above. The K circuit elements 122a through 122k would then be selected in a systematic manner. For example, an input data value of 1 may always select circuit element 122a, an input data value of 2 may always select circuit elements 122a and 122b, etc. Since there may be mismatches in the K circuit elements, the systematic selection of these circuit elements may result in the analog output signal having degraded performance, e.g., poor THD.
Referring back to
The DWA design in
The zero position may be at one of eight possible places corresponding to the eight generators G0 through G7. Thus, depending on the current zero position, there are eight different ways to represent a given input data value. Which select signals to assert (and hence which circuit elements to select) is pseudo-randomized through the different possible ways of representing the input data based on the state of the registers.
The DWA design in
In the design shown in
Thermometer decoder 410 receives 3-bit input data D0, D1 and D2 and generates eight decoded signals Th0 through Th7. Decoder 410 asserts the decoded signals in a predetermined order, starting with decoded signal Th0, based on the input data value.
Table 1 gives the logic value of the eight decoded signals Th0 through Th7 for each possible 3-bit input data value. As shown in
Table 1, decoder 410 asserts only one decoded signal Th0 for an input data value of 1, asserts two decoded signals Th0 and Th1 for an input data value of 2, and so on, and asserts seven decoded signals Th0 through Th6 for an input data value of 7.
Signal mapping circuit 430 receives the eight decoded signals Th0 through Th7 and provides eight select signals Sel0 through Sel7. In the design shown in
The eight decoded signals may be denoted by an 8-element set T0={Th0, Th1, Th2, Th3, Th4, Th5, Th6, Th7}. A circular rotation of the eight decoded signals by m positions may be achieved by taking the first m elements in set T0 and moving these m elements to the end of set T0 obtain a circularly rotated set Tm. For example, a circular rotation of 1 position may be given as T1={Th1, Th2, Th3, Th4, Th5, Th6, Th7, Th0}. The eight decoded signals Th0 through Th7 are provided directly to input 0 of multiplexers 0 through 7, respectively. The eight decoded signals circularly rotated by one position are provided to input 1 of the eight multiplexers. In general, the eight decoded signals circularly rotated by m positions are provided to input m of the eight multiplexers, where 0≦m≦7.
Table 2 gives the mapping of the eight decoded signals to the eight inputs of each multiplexer. For example, multiplexer 0 receives decoded signal Th0 at input 0, decoded signal Th7 at input 1, and so on, and decoded signal Th1 at input 7.
All eight multiplexers 0 through 7 receive the same 3-bit control Z. Control Z indicates the current zero position and may be generated as described below. When control Z is equal to m, the decoded signals at input m of multiplexers 0 through 7 are provided as select signals Sel0 through Sel7, respectively. Multiplexers 0 through 7 thus map decoded signals Th0 through Th7 to select signals Sel0 through Sel7 based on the current zero position indicated by control Z.
The mapping of the decoded signals to the select signals for other values of control Z are shown in Table 2. Different select signals are asserted first for different values of control Z, as indicated by the shifting position of decoded signal Th0 for different control Z values.
In the design shown in
In the DWA mode, the zero position is updated based on the input data, and the select signals are asserted starting with the select signal at the current zero position. In the pseudo-random mode, the zero position is updated based on pseudo-random data, and the select signals are asserted starting with the select signal at the current zero position. The DWA mode and the pseudo-random mode differ in how the zero position is updated. The zero position may also be updated in other manners, e.g., based on a fraction of the input data, based on a combination of the input data and pseudo-random data, based on a fixed non-zero value, etc. In the bypass mode, the select signals are essentially generated based on thermometer decoding, without any randomization. Other modes of operation may also be supported. For example, the zero position may be updated by a fixed non-zero value (e.g., 1, 2, etc.) in each sample period and may thus be shifted at a constant rate.
Within DEM unit 420, a multiplexer 612 receives the input data at a first input, pseudo-random data from a pseudo-random number (PN) generator 610 at a second input, and a value of 0 at a third input. Multiplexer 612 provides the input data when the DWA mode is selected, the pseudo-random data when the pseudo-random mode is selected, and 0 when the bypass mode is selected, as indicated by a mode select. A summer 614 sums the control data from multiplexer 612 with the current control value from a register 616 and provides an updated control value to register 616. Register 616 provides the current control value as the N-bit control Z to signal mapping circuit 430.
Summer 614 and register 616 implement a wrap-around accumulator that updates the zero position based on the control data from multiplexer 612. In the DWA mode, the zero position is updated based on the input data from multiplexer 612. In the pseudo-random mode, the zero position is updated based on the pseudo-random data from multiplexer 612. In the bypass mode, register 616 is initialized to zero, and the zero position is updated with 0 from multiplexer 612 and hence does not change.
PN generator 610 may be implemented with a linear feedback shift register (LFSR) having a length greater than N. The LFSR may implement any primitive polynomial generator function. The N least significant bits (LSBs) of the LFSR may be provided as N-bit pseudo-random data. The pseudo-random data may also be obtained in other manners, e.g., with a look-up table.
Within DAC 800, an N-bit flip-flop 812 receives N-bit input data, clocks the input data with a clock, and provides N synchronized data bits D0 through DN-1 in each sample period. A thermometer decoder 814 receives the N data bits and provides K decoded signals Th0 through ThK-1. A DEM unit 816 receives the K decoded signals Th0 through ThK-1 and provides K select signals Sel0 through SelK-1. DEM unit 816 may be implemented with DEM unit 420 shown in
K latches/drivers 818 receive the K select signals and provide K control signals for K switches 820. K switches 820 also receive the K reference currents of equal amount from K current sources 822. Each of the K switches 820 steers its reference current to either an Outp output or an Outn output based on its control signal. Latches 818 ensure synchronous switching of the K reference currents in order to reduce glitch energy in the Outp or Outn signals. A bias circuit 824 generates a bias voltage for K current sources 822.
The dynamic element selection techniques described herein may provide certain advantages. The techniques may be used to flexibly support different modes such as those given in Table 3. The techniques may also support various randomization schemes through flexibility in the design of the signal mapping circuit and the control circuit. Furthermore, the control circuit may be initialized to zero (for the bypass mode) or an arbitrary value (for the other modes), which avoids the need for special initialization circuitry such as the one required for the DWA design shown in
The techniques described herein may be used for various electronics devices such as wireless communication devices, handheld devices, gaming devices, computing devices, computers, laptop computers, consumer electronics devices, etc. An exemplary use of the techniques for a wireless communication device is described below.
Wireless device 900 is capable of providing bi-directional communication via a receive path and a transmit path. On the receive path, signals transmitted by base stations (not shown) are received by an antenna 912 and provided to a receiver (RCVR) 914. Receiver 914 conditions the received signal and provides an analog input signal to an application specific integrated circuit (ASIC) 920. On the transmit path, a transmitter (TMTR) 916 receives and conditions an analog output signal from ASIC 920 and generates a modulated signal, which is transmitted via antenna 912 to the base stations.
ASIC 920 may include various processing, interface, and memory units such as, e.g., a receive ADC (Rx ADC) 922, a transmit DAC (Tx DAC) 924, a modem processor 926, a reduced instruction set computing (RISC) processor 928, a controller/processor 930, an internal memory 932, an external bus interface 934, an input/output (I/O) driver 936, an audio DAC/driver 938, and a video DAC/driver 940. Rx ADC 922 digitizes the analog input signal from receiver 914 and provides digital samples to modem processor 926. Tx DAC 924 converts digital output chips from modem processor 926 to analog and provides the analog output signal to transmitter 916. Modem processor 926 performs processing for data transmission and reception, e.g., encoding, modulation, demodulation, decoding, etc. RISC processor 928 may perform various types of processing for wireless device 900, e.g., processing for video, graphics, higher layer applications, etc. Controller/processor 930 may direct the operation of various processing and interface units within ASIC 920. Internal memory 932 stores data and/or instructions for various units within ASIC 920.
EBI 934 facilitates transfer of data between ASIC 920 and a main memory 944. I/O driver 936 drives an I/O device 946 via an analog or digital interface. Audio DAC/driver 938 drives an audio device 948, which may be a speaker, a headset, an earpiece, etc. Video DAC/driver 940 drives a display unit 950, which may be a liquid crystal display (LCD), etc. Rx ADC 922, Tx DAC 924, audio DAC/driver 938, video DAC/driver 940, and/or other units may implement the techniques described herein. For example, any of the DACs may be implemented as shown in
The techniques described herein may be implemented in various hardware units such as an integrated circuit (IC), an ASIC, a digital signal processor (DSP), a digital signal processing device (DSPD), a programmable logic device (PLD), a field programmable gate array (FPGA), a controller, a processor, and other electronic devices. The hardware units may be fabricated in various IC process technologies such as complementary metal oxide semiconductor (CMOS), N-channel MOS (NMOS), P-channel MOS (PMOS), bipolar-CMOS (Bi-CMOS), bipolar, etc. The hardware units may be fabricated with any device size technology, e.g., 130 nanometer (nm), 90 nm, 65 nm, 45 nm, 32 nm, etc.
The techniques described herein may be used for Tx DACs, ΣΔ DACs, audio DACs, video DACs, instrumentation DACs, Rx ADCs, ΣΔ ADCs, filters, etc. The DACs and ADCs may be implemented with P-FETs, N-FETs, bipolar junction transistors (BJTs), GaAs transistors, hetero-junction bipolar transistors (HBTs), high electron mobility transistors (HEMTs), etc. The DACs and ADCs may also be fabricated on various types of IC such as analog ICs, digital ICs, mixed signal ICs, radio frequency ICs (RFICs), etc.
The previous description of the disclosure is provided to enable any person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the spirit or scope of the disclosure. Thus, the disclosure is not intended to be limited to the examples and designs described herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
The various illustrative logical blocks, modules, and circuits described in connection with the embodiments disclosed herein may be implemented or performed with a general purpose processor, a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), a Field Programmable Gate Array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm described in connection with the embodiments disclosed herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in Random Access Memory (RAM), flash memory, Read Only Memory (ROM), Electrically Programmable ROM (EPROM), Electrically Erasable Programmable ROM (EEPROM), registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.
In one or more exemplary embodiments, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
The previous description of the disclosed exemplary embodiments is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these exemplary embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the spirit or scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
The present Application for Patent claims priority to Provisional Application No. 60/915,906 entitled “Zero-position-based Data Weight Average (DWA)” filed May 3, 2007, and assigned to the assignee hereof and hereby expressly incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
6348884 | Steensgaard-Madsen | Feb 2002 | B1 |
6469648 | Nakao et al. | Oct 2002 | B2 |
6690313 | Warren et al. | Feb 2004 | B1 |
6762702 | Kwan | Jul 2004 | B2 |
6952123 | Kizer et al. | Oct 2005 | B2 |
20050040979 | Brooks et al. | Feb 2005 | A1 |
Number | Date | Country |
---|---|---|
1179889 | Feb 2002 | EP |
Number | Date | Country | |
---|---|---|---|
20080272948 A1 | Nov 2008 | US |
Number | Date | Country | |
---|---|---|---|
60915906 | May 2007 | US |