This application is based upon and claims the benefit of priority from Japanese patent application No. 2015-168502, filed on Aug. 28, 2015, the disclosure of which is incorporated herein in its entirety by reference.
The present invention relates to an AD converter, an AD convert apparatus, and an AD convert method. For example, the present invention relates to an AD converter, an AD convert apparatus, and an AD convert method which perform successive approximation.
A successive approximation register (SAR) ADC (SAR-ADC) is known as an ADC (an A/D converter: an analog/digital converter) that converts an input analog signal into a digital signal. The SAR-ADC mainly includes a DAC (a D/A converter: a digital/analog converter), a comparator, and a successive approximation logic circuit. The SAR-ADC performs AD conversion by sampling and holding an input analog signal and performing a successive approximation operation on the input analog signal, and outputs a digital signal as a result of the successive approximation. As a related art of the SAR-ADC, for example, H. Lee et. al., “A Self-Calibrating 15 bit CMOS A/D Converter”, IEEE Solid State Circuits, vol. sc-19, No. 6, December 1984 (hereinafter referred to as “Non Patent Literature 1”); Hideo Nakane et. al., “A Fully Integrated SAR ADC Using Digital Correction Technique for Triple-Mode Mobile”, ASSOC, Session 5-2 November 2013 (hereinafter referred to as “Non Patent Literature 2”); Japanese Unexamined Patent Application Publication No. H05-167449; and Japanese Patent Nos. 3224808, 4806021, 4890561, and 5565169 are known.
To achieve an accuracy required for a high-accuracy SAR-ADC, a high relative accuracy is required for analog elements (capacitors and resistors) constituting a built-in DAC. However, to achieve, for example, a 14-bit or higher ADC, the device size necessary for securing the relative accuracy (pair accuracy) of the analog elements increases. Accordingly, in the ADC of the related art, it is necessary to increase the relative accuracy by increasing the element area.
Non Patent Literature 1 discloses an ADC that calibrates errors in analog elements so as to increase the relative accuracy of the analog elements. Non Patent Literature 1, Japanese Unexamined Patent Application Publication No. H05-167449, and Japanese Patent No. 5565169 employ a technique in which a mismatch between elements is obtained as a digital value and the digital value is fed back in an analog fashion during AD conversion processing.
Non Patent Literature 2 discloses a digital correction ADC that uses a non-binary-weighted capacitive DAC and an LMS (Least Mean Square) engine. Non Patent Literature 2 and Japanese Patent. No. 3224808 employ a technique in which a result of a mismatch between elements is obtained as a digital value and the digital value is corrected in a digital fashion after AD conversion. Japanese Patent No. 3224808 discloses an example of the digital correction in which the technique disclosed in Non Patent Literature 1 is applied to a non-binary-weighted DAC with redundancy.
In addition, Japanese Patent Nos. 4806021 and 4890561 disclose an ADC to reduce thermal noise.
However, the present inventors have found that an improvement in the accuracy of the conversion in the ADCs of the related art may adversely affect the processing speed thereof. Accordingly, the ADCs of the related art have a problem that it is difficult to improve the processing speed while achieving a high accuracy.
Other problems to be solved by and novel features of the present invention will become apparent from the following description and the accompanying drawings.
According to one embodiment, an AD converter includes a higher-order DAC, an extension DAC, a lower-order DAC, a comparator, and a successive approximation logic circuit. The higher-order DAC samples an analog input signal and performs DA conversion corresponding to higher-order bits of a digital output signal. The extension DAC performs DA conversion to positive and negative polarities on an extension bit for expanding bits of the higher-order DAC. The lower-order DAC performs DA conversion corresponding to lower-order bits of the digital output signal. The comparator compares a comparison reference voltage with an output voltage of each of the higher-order DAC, the extension DAC, and the lower-order DAC. The successive approximation logic circuit controls the successive approximation performed by the higher-order DAC, the extension DAC, and the lower-order DAC, based on a comparison result of the comparator, and generates the digital output signal.
According to the one embodiment, it is possible to improve a processing speed while achieving a high accuracy of AD conversion.
The above and other aspects, advantages and features will be more apparent from the following description of certain embodiments taken in conjunction with the accompanying drawings, in which:
The following description and the drawings are abbreviated or simplified as appropriate for clarity of explanation. The elements illustrated in the drawings as functional blocks for performing various processes can be implemented hardwarewise by a CPU, a memory, and other circuits, and softwarewise by a program loaded into a memory. Accordingly, it is understood by those skilled in the art that these functional blocks can be implemented in various forms including, but not limited to, hardware alone, software alone, and a combination of hardware and software. Note that in the drawings, the same elements are denoted by the same reference numerals, and repeated descriptions thereof are omitted as needed.
(Investigation Leading to Embodiments)
As described above, in order to increase a relative accuracy without performing a correction by calibration in an SAR-ADC, it is necessary to increase the area of analog elements. For example, capacitor elements are used as the analog elements constituting the SAR-ADC. When the capacitance of each capacitor element is increased to improve the accuracy of the SR-ADC, an increase in the capacitance of each element, as well as an increase in element area causes deterioration in processing speed and an increase in power consumption due to charge and discharge. Thus, the area, power, and speed of the SAR-ADC are scarified as a trade-off for a high accuracy.
In the technique for correcting errors in analog elements as typified by Non Patent Literature 1, Japanese Unexamined Patent Application Publication No. H05-167449, and Japanese Patent No. 5565169, it is necessary for the DAC that provides a correction value to perform a step-by-step operation during AD conversion. Accordingly, it is necessary to increase the area of the DAC for correction and to perform arithmetic processing for converting each AD conversion value into a correction code, which incurs an overhead in terms of processing speed.
As disclosed in Non Patent Literature 2, there is a method for correcting an error in post-processing after AD conversion by using an AD conversion result. In this method, a non-binary-weighted DAC with redundancy is used. For example, this method uses a characteristic that the redundancy of the DAC allows the value of a local DAC obtained as a result of a final conversion of the SAR-ADC to be set to an output corresponding to an analog input value, even if the relative accuracy does not meet the accuracy required by the ADC. Performing a correction in post-processing makes it possible to solve the overhead in terms of circuit configuration and processing speed during normal AD conversion. In this method, however, it is necessary to, for example, derive a correction coefficient during the correction in post-processing by using the LMS engine that performs complicated statistical processing. Thus, the method has a problem that as the gate area of an arithmetic circuit for deriving a correction coefficient increases, a longer correction time is required for statistical processing.
The following embodiments make it possible to prevent adverse effects on the processing speed and the like, while achieving a high accuracy. Specifically, it is possible to provide an ADC that facilitates design of a DAC and is capable of performing AD conversion using a binary DAC with simple operation.
A first embodiment will be described below with reference to the drawings.
<Outline of First Embodiment>
In the first embodiment, a power-of-two-weighted (binary-weighted) redundant element (extension DAC) is added to a local DAC which is composed of power-of-two-weighted (binary-weighted) analog elements. With this configuration, the output range of the local DAC is expanded and the number of times of comparison is increased, thereby providing a successive approximation ADC with the redundancy of the power-of-two-weighted redundant element that is additionally provided.
The configuration of the binary-weighted DAC enables the derivation of the error correction in the same manner as in Non Patent Literature 1. However, since the ADC of the first embodiment has redundancy, there is no need to perform the error correction for the DAC every time a comparison is made, unlike in Non Patent Literature 1. Therefore, a correct conversion result can be obtained by subtracting the error in the DAC from the digital code of the final conversion result.
This eliminates the need for arithmetic processing and accessing a register to obtain a correction value during the comparison, which leads to an improvement in conversion rate. As one feature, a reference DAC for correction (correction target DAC) also serves as a lower-order DAC, and thus there is no need to separately provide a DAC for correction. The error in the reference DAC can be corrected by a particular correction coefficient calculation method.
The correction result can be stored in a register and is accessible from the outside. The correction result can also be transferred to a flash-ROM through the register and stored in the flash-ROM. During screening of a semiconductor device, the correction result is stored in the flash-ROM and loaded into the register upon activation of the semiconductor device, thereby making it possible to perform an AD conversion operation without deriving the correction coefficient.
For example, the basic main components of the first embodiment include: a DAC including binary-weighted elements; a binary-weighted extension DAC having positive and negative polarities; a lower-order DAC used as a correction reference; a comparator; a successive approximation logic; a correction coefficient derivation logic (calibration engine); a correction result arithmetic logic (correction value calculation circuit); a correction coefficient storage register; and an ADC control logic (controller).
<Configuration of MCU>
As shown in
The CPU 2, the RAM 3, the flash-ROM 4, the I/O port 5, the other peripherals 6, and the register 9 are connected via the bus 7. An input terminal of the ADC 100 is connected to the analog port 11, and an output terminal (and a control terminal) of the ADC 100 is connected to the controller 8. The controller 8 is also connected to each of the calibration engine 10 and the register 9.
The CPU 2 is an arithmetic processing unit that implements functions necessary for the MCU 1. The CPU 2 accesses the RAM 3 and the flash-ROM 4 and executes various programs, to thereby execute arithmetic processing on the AD conversion result of the ADC 100 that is stored in the register 9, input and output signals through the I/O port, and input and output signals through the other peripherals 6.
For example, the ADC 100, the controller 8, the register 9, and the calibration engine 10 constitute an AD conversion unit (AD convert apparatus) 101 that performs an AD conversion and correction (calibration). The ADC 100, the controller (correction unit) 8, and the register 9 may constitute the AD conversion unit 101.
The ADC 100 is an AD converter which is a main feature of the first embodiment. The ADC 100 performs AD conversion on an analog input signal which is input to the analog port 11 from the outside of the MCU, and outputs a digital output signal as a result of the AD conversion. The controller 8 is a control circuit that controls the operation of the ADC 100 and exchange of data between the calibration engine 10 and the register 9. The ADC 100 operates according to the control from the controller 8, and outputs the AD conversion result before correction. The controller 8 executes correction processing on the AD conversion result of the ADC 100.
The calibration engine 10 executes a calibration operation (processing) for the ADC 100. The calibration operation is an operation for correcting an error in the ADC. Specifically, in the calibration operation, a correction coefficient to correct the AD conversion result of the ADC is calculated. For example, a signal from the calibration engine 10 is transmitted to the ADC 100 through the controller 8, to thereby control the operation of the ADC 100 necessary for the calibration operation. The calibration engine 10 may directly control the ADC 100 without involving the controller 8.
A corrected AD conversion result or a correction coefficient necessary for correction is stored in the register 9 through the controller 8, and is used for control processing of the MCU 1. The correction coefficient is transferred from the register 9 to the flash-ROM 4, and the value of the correction coefficient can be held in the flash-ROM 4 even after a power supply is out off. By loading the value from the flash-ROM 4 upon a subsequent startup of the MCU, the ADC 100 can omit the calculation for correction (calibration), and thus can start the AD conversion operation immediately.
<Correction Coefficient Write/Read Operation>
As shown in
After that, as shown in
Since the error ε calculated in the first embodiment is caused due to a mismatch between capacitances, the power supply voltage drift, temperature drift, or the like is small. Accordingly, if the correction coefficient (error ε) obtained during mass production and screening of the MCU is stored in the flash-ROM, there is no need to derive the correction coefficient every time the MCU is started, and thus the time required for deriving the correction coefficient upon start-up of the MCU can be reduced. If the error ε varies due to a change in use environment, aged deterioration, or the like, the calibration may be executed again at a necessary timing after shipment of the MCU 1 to update the correction coefficient.
<Configuration of ADC>
As shown in
The local DAC 110 is a capacitive DAC that samples an analog input signal and redistributes the sampled charge. The local DAC 110 includes capacitor elements CN . . . C0, CRP, and CRN and switches SN . . . S0, SRP, and SRN.
The capacitor elements CN . . . C0, CRP, and CRN are connected in parallel between the switches SN . . . S0, SRP, and SRN and a node NP (one of input terminals of the comparator 130). The switches SN . . . S1 are provided between the capacitor elements CN . . . C1 and each of an input terminal for the ADC analog input signal, a supply terminal for a reference voltage VREF_HIGH, and a supply terminal for a reference voltage VREF_LOW. The switch S0 is provided between the capacitor element C0 and each of the input terminal for the ADC analog input signal and an output terminal of the lower-order DAC 120. The switches SRP and SRN are provided between the capacitor elements CRP and CRN and each of the supply terminal for the reference voltage VREF_HIGH and the supply terminal for the reference voltage VREF_LOW.
Switching operations of the switches SN . . . S0, SRP, and SRN are respectively controlled by successive approximation control signals BN . . . B1, B0, BRP, and BRN, which are output from the successive approximation logic 140. The switches SN . . . S1, SRP, and SRN switch the connections between the capacitor elements CN . . . C1, CRP, and CRN and each of the reference voltage VREF_HIGH, the reference voltage VREF_LOW, and the ADC analog input signal according to the successive approximation control signals BN . . . B1, BRP, and BRN. The switch S0 switches the connection between the capacitor element C0 and each of the ADC analog input signal and the output signal of the lower-order DAC 120 according to the successive approximation control signal B0.
The lower-order DAC 120 is an M-bit DAC. The lower-order DAC 120 performs DA conversion on successive approximation control signals BLM . . . BL0, which are output from the successive approximation logic 140, and supplies analog signals obtained as a result of the DA conversion to the capacitor element C0 via the switch S0. The lower-order DAC 120 (and the capacitor element C0) performs DA conversion corresponding to lower-order bits (M bits) of the digital output signal. The capacitor element (coupling capacitor element) C0 and the switch (coupling switch) S0 may be or may not be included in the lower-order DAC 120. The capacitor element C0 has the same capacity as that of the capacitor element corresponding to the least significant bit of the higher-order DAC.
The higher-order DAC 111 is an N-bit DAC, and includes the capacitor elements CN . . . C1 (higher-order capacitor element group) and the switches SN . . . S1 (higher-order switch group). The capacitor elements CN . . . C1 each have a capacitance of a weight that is a power-of-two multiple of the reference capacitor element C0. The capacitances of the capacitor elements CN . . . C0are also referred to as capacitances CN . . . C0 (or simply as CN . . . C0), respectively. Specifically, the capacitance of the capacitor element C1 at the least significant bit is represented by C0, and the capacitance of the capacitor element CN at the most significant bit is represented by 2N−1×C0. The higher-order DAC 111 samples the analog input signal according to the successive approximation control signals BN . . . B1 and performs DA conversion corresponding to the higher-order bits (N bits) of the digital output signal.
The extension DAC 112 is a 1-bit DAC for providing the DAC (for example, the bits of the higher-order DAC) with redundancy, and includes the capacitor elements (extension capacitor elements) CRP and CRN and the switches (extension switches) SRP and SRN. The capacitor elements CRP and CRN each have a capacitance of a weight that is a power-of-two multiple of the weight of the reference capacitor element C0 so that the capacitance of each of the capacitor elements CRP and CRN matches the capacitance of any one of the capacitor elements in the higher-order DAC. In other words, each of the capacitor elements CRP and CRN has a capacitance equal to that of any one of the capacitor elements in the higher-order DAC, and the capacitance of each of the capacitor elements CRP and CRN is set to C0 in this example. The extension DAC 112 has positive and negative polarities, and each of the capacitor elements CRP and CRN has positive and negative polarities. The positive polarity and the negative polarity respectively indicate the positive side and the negative side of the input or output of the DAC. It can be said that, in this example, the DAC is expanded by one bit to each of the positive side and the negative side. For example, the capacitor element CRP is connected to the reference voltage VREF_LOW, and the capacitor element CRN is connected to the reference voltage VREF_HIGH. The extension DAC 112 corresponds to an extension bit for expanding the bits of the higher-order DAC 111, and performs DA conversion to the positive and negative polarities (first and second potentials).
The comparator 130 compares a comparison reference voltage Vcm (comparison reference voltage) with an output voltage of each of the higher-order DAC 111, the extension DAC 112, and the lower-order DAC 120. One of the input terminals of the comparator 130 is connected to the capacitor elements CN . . . C0, CRP, and CRN, and the other one of the input terminals of the capacitor 130 is connected to the comparison reference voltage Vcm. An output terminal of the comparator 130 is connected to the successive approximation logic 140. A switch SC is provided between the one (node NP) of the input terminals of the comparator 130 and the other input terminal thereof (comparison reference voltage Vcm). For example, turning on/off of the switch SC is controlled by the controller 8 or the successive approximation logic 140. During a sampling operation, the switch SC is turned on, so that the comparator 130 does not perform the comparison. During the successive approximation operation, the switch SC is turned off, so that the comparator 130 compares the comparison reference voltage Vcm with the charge redistributed by the capacitor elements CN . . . C0, CRP, and CRN, and outputs the comparison result to the successive approximation logic 140.
The successive approximation logic (successive approximation logic circuit) 140 controls the successive approximation performed by the successive approximation control signals BN . . . B1, B0, BRP, BRN, and BLM . . . BL0 based on the comparison result of the comparator 130. The successive approximation logic 140 outputs, to the controller 8, the (N+M)-bit AD conversion result ADPRE before correction as the digital output signal according to the successive approximation result.
The first embodiment illustrates an example in which the ADC has a single end configuration as shown in
Referring to
Specifically, the ADC 100 shown in
The comparator 130 compares the charge (node NP) of the capacitor elements CN . . . C0, CRP, and CRN in the local DAC 110a with the charge (node NN) of the capacitor elements CN . . . C0, CRP, and CRN in the local DAC 110b, and outputs the comparison result to the successive approximation logic 140. The successive approximation logic 140 controls the successive approximation of the local DAC 110a and the lower-order DAC 120a by the successive approximation control signals BN . . . B1, B0, BRP, BRN, and BLM . . . BL0 based on the comparison result of the comparator 130, and controls the successive approximation of the local DAC 110b and the lower-order DAC 120b by inverted signals of the successive approximation control signals BN . . . B1, B0, BRP, BRN, and BLM . . . BL0.
The first embodiment can be widely applied to charge redistribution SAR-ADCs using capacitor elements, and is not limited to the configurations of the capacitive DACs, comparators, switches, and the like shown in
<AD Conversion Operation>
Next, as an operation according to the first embodiment, a normal AD conversion operation in a state where a correction coefficient is fixed (after derivation of the correction coefficient) will be described.
In the case of performing AD conversion, the ADC 100 first samples an ADC analog input signal.
Subsequently, when the sampling is finished, the ADC 100 performs a successive approximation operation.
The successive approximation logic 140 sequentially controls the successive approximation control signals BN . . . B0 so that the voltage at the node NP matches the comparison reference voltage Vcm, and the comparator 130 performs the comparison N times. After the comparison is performed N times, when the comparison result (the voltage at the node NP<the comparison reference voltage Vcm) of the comparator 130 is detected, the successive approximation control signal BRP is switched and the voltage to be selected by the switch SRP is shifted from VREF_LOW to VREF_HIGH. When the comparison result (the voltage at the node NP>the comparison reference voltage Vcm) of the comparator 130 is detected, the successive approximation control signal B1 is switched so that the switch S1 of the capacitor element C1 is switched to shift the voltage to be selected by the switch S1 from VREF_HIGH to VREF_LOW, and then the comparison is performed again. The conversion in this comparison operation is a redundant conversion.
After the successive approximation performed by the higher-order DAC 111, the lower-order DAC 120 connected to the capacitor element C0 performs successive approximation. At this time, when the code (successive approximation result) is shifted to the negative side, the successive approximation control signal BRN is switched to shift the voltage to be selected by the switch SRN, which is connected to the capacitor element CRN, from VREF_HIGH to VREF_LOW, and the output of the lower-order DAC 120 is set to the value of (VREF_HIGH-VREF_LOW)/2 according to the successive approximation control signals BLM . . . BL0. The successive approximation logic 140 sequentially controls the successive approximation control signals BLM . . . BL0, and the comparator 130 performs the comparison M times. When the comparison is performed M times using the lower-order DAC 120, the (N+M)-bit AD conversion result ADPRE before correction is obtained.
The conversion result of the redundant successive approximation can be expressed as follows. When the bits of the successive approximation control signals BN . . . B1 indicate 1, the reference voltage VREF_HIGH is selected. When the bits of the successive approximation control signals BN . . . B1 indicate 0, the reference voltage VREF_LOW is selected. The bits of the successive approximation control signals BRP and BRN indicate 1 when the state is shifted (switched) during comparison, and the bits of the successive approximation control signals BRP and BRN indicate 0 when the sampling state is held. At this time, the successive approximation conversion result ADPRE of the ADC 100 before correction is expressed by the following formula (1).
By the formula (1), multiplications for the operation to derive the code (successive approximation result) can be substituted by bit shift. Accordingly, the successive approximation logic for performing the operation can be configured using only an adder/subtractor. Consequently, a simple circuit configuration can be achieved.
<Characteristics of Extension DAC>
As one of the features of the first embodiment, the extension DAC having positive and negative polarities will be described below.
A configuration in which the extension DAC as illustrated in the first embodiment is not provided will now be considered as a reference example.
On the other hand, when the extension DAC is introduced like in the first embodiment, the DAC of the first embodiment has characteristics as shown in
Further, when the redundant conversion by the extension DAC is considered, a configuration using only one extension DAC that operates in the positive polarity can be employed. In this case, however, the following problem arises.
For example, the transition of a high-order 3-bit (N=3) ADC digital code and a lower-order 3-bit (M=3) ADC digital code is considered.
In the reference example shown in
As shown in
The bit B3 that is the MSB of the digital code changes due to a transition from the fourth comparison, which is a redundant comparison, to a fifth comparison. Specifically, in the fifth comparison, the analog input signal is compared with the capacitance C1+C2+C0/2 according to a digital code=011_0_100. In this comparison, it is determined that the analog input signal is greater than the capacitance. Accordingly, in a sixth comparison, the analog input signal is compared with the capacitance C1+C2+C0/2+C0/4 according to a digital code=011_0_110. In a seventh comparison, the analog input signal is compared with the capacitance C1+C2+C0/2+C0/4+C0/8 according to a digital code=011_0_111.
Since the error of C3−(C2+C1+C0)=8LSB is considered in the reference example, the error at this time cannot be recovered by the fifth to seventh conversions. Thus, it is obvious that the value of the local DAC in the final conversion still has an error of 1.5 LSB.
Next, the example shown in
As shown in
Thus, in the first embodiment, in a transition from the fourth comparison, which is a redundant comparison, to the fifth comparison, the capacitor element CRN of the negative-side extension DAC operates to thereby enable the transition of the comparison without changing the bit B3. Therefore, the output value of the local DAC in the final comparison is shifted within a range of a difference of 0.5 LSB from the analog input signal, and thus the correct conversion result can be obtained. On the basis of the above considerations, in the first embodiment, the positive and negative polarities are introduced in the extension DAC, which makes it possible to recover an error in the higher-order DAC and to achieve the transition of the local DAC which is capable of performing digital correction.
<Error Correction Operation After AD Conversion>
Next, an error correction operation for an AD conversion. result in the controller according to the first embodiment will be described. Assuming that an error of a capacitance of a capacitor element based on a capacitance of a reference capacitor element is represented by ε, errors in the respective capacitor elements are expressed by the following formulas.
ε(N)=CNi−CN (2.1)
ε(N−1)=C(N−1)i−C(N−1) (2.2)
ε2=C2i−C2 (2.3)
ε1=C1i−C1 (2.4)
ε0=C0i−C0 (2.5)
εRP=CRPi−CRP (2.6)
εRN=CRNi−CRN (2.7)
In these formulas, CNi, C (N−1)i . . . C2i, C1i, C0i, CRPi, and CRNi represent ideal capacitance values. Examples of criteria for the ideal capacitance values may include an ideal value assumed from a total (full-scale) capacitance value which contributes to sampling, and a difference between a capacitance value and a reference capacitance value for correction. In the first embodiment, the correction can be performed based on these two criteria, and the details thereof will be described later.
The corrected AD conversion result ADOUT can be obtained as follows. In the following formula, the correction is not performed on the lower-order DAC. However, the correction may also be performed on the lower-order DAC.
First, the error correction value calculation circuit 81 reads the error ε from the register 9, and calculates an error correction value ADERR corresponding to the code by the following formula.
ADERR=εN*BN+ε(N−1)*B(N−1)+ . . . +ε2*B2+ε1*B1+εRP*BRP−εRN*BRN+ε0*(BLSB) (3)
In the formula (3), BLSB represents a signal corresponding to the code of the lower-order DAC. The value of the signal BLSB varies depending on the correction method, and thus the detailed description thereof is omitted.
After that, the subtractor 82 subtracts the error correction value ADERR from the AD conversion result ADPRE before correction as shown in the following formula, thereby obtaining the corrected AD conversion result ADOUT. The subtractor 82 outputs the obtained corrected AD conversion result ADOUT to the register 9.
ADOUT=ADPRE−ADERR (4)
<Error Calculation Method During Calibration>
Next, a method for calculating the error ε in the calibration engine according to the first embodiment will be described. The method for calculating the error ε is basically similar to that disclosed in Non Patent Literature 1. In the first embodiment, since the local DAC is composed of capacitances weighted by a power of two, the capacitances have the following relations.
CN=C(−1)+ . . . +C2+C1+C0 (5.1)
C(N−1)=C(N−2)+ . . . +C2+C1+C0 (5.2)
C3=C2+C1+C0 (5.3)
C2=C1+C0 (5.4)
C1=C0 (5.5)
C0=CRP (5.6)
C0=CRN (5.7)
A difference between the capacitances is first obtained using the relations described above. A difference E between the capacitances can be expressed as follows.
EN=CN−{C(N−1)+ . . . +C2+C1+C0} (6.1)
E(N−1)=C(C−1)−{C(N−2)+ . . . +C2+C1+C0} (6.2)
E3=C3−{C2+C1+C0} (6.3)
E2=C2−(C1+C0} (6.4)
E1=C1−C0 (6.5)
ERP=CRP−C0 (6.6)
ERN=CRN−C0 (6.7)
The above formulas can be modified in the following manner as errors with respect to the capacitance C0.
C2−2C0=E1+E2 (7.1)
C3−4C0=2E1+E2+E3 (7.2)
C4−8C0=4E1+2E2+E3+E4 (7.3)
Next, two methods for obtaining the error ε using the above formulas will be described.
(Method 1) The Error ε is Obtained Based on the Capacitance C0.
This method is based on the capacitance C0 and obtains the error ε from the difference between a capacitance and the capacitance C0. In this case, the error ε can be simply obtained by the above formulas (7.1) to (7.4). Accordingly, the error ε based on the capacitance C0 can be obtained by the following formulas.
ε1=C0−C1=−E1 (8.1)
ε2=2C0−C2=−(E1+E2) (8.2)
ε3=4C0−C3=−(2E1+E2+E3) (8.3)
ε4=8C0−C4=−(4E1+2E2+E3+E4) (8.4)
εN=2(N−1)*C0−CN=−(2(N−2)E1+2(N−3)E2+2(N−4)E3+ . . . +2E(N−2)+E(N−1)+EN) (8.5)
εRP=C0−CRP=−ERP (8.6)
εRN=C0−CRN=−ERN (8.7)
The calibration engine 10 obtains the error ε based on the formulas (8.1) to (8.7) and stores the obtained error in the register 9. After that, the controller 8 corrects the AD conversion result ADPRE using the error ε as described above with reference to
ADERR=εN*BN+ε(N−1)*B(N−1)+ . . . +ε2*B2+ε1*B1+εRP*BRP−εRN*BRN (9)
This method has a problem that, since the error ε is obtained based on the capacitance C0, the error value of the capacitance CN is increased to about 2N−1. In other words, such a large error appears as a gain error in the corrected AD conversion result ADOUT. In order to avoid this problem, the controller 8 needs to be additionally provided with a gain correction circuit 83 that corrects the gain of the corrected conversion result as shown in
ADOUT=(1/GERR)(ADPRE−ADERR) (10)
(Method 2) The Error ε is Pbtained Based on a Full-Scale Capacitance.
As described above, when the error ε is obtained based on the capacitance C0, the circuit for gain correction is required. The calculation method which eliminates the need for gain correction by obtaining the error ε in advance based on the full-scale capacitance (of all capacitor elements) will now be described. Assuming that the entire capacitance value that contributes to sampling is represented by Ctot, Ctot is expressed by the following formula and the error ε is obtained based on the capacitance value Ctot.
Ctot=CN+C(N−1)+ . . . +C3+C1+C0 (11)
The capacitance Ctot can be obtained based on the capacitance C0 by modifying the formulas (6.1) to (6.7) and the formulas (7.1) to (7.4) as follows.
Ctot=2N*C0+2(N−1)E1+2(N−2)E2+2(N−3)E3+ . . . +2(N−(N−2))E(N−2)+2(N−(N−1))E(N−1)+EN=2N*C0+2(N−1)E1+2(N−2)E2+2(N−3)E3+ . . . +4E(N−2)+2E(N−1)+EN (12)
On the basis of this formula, the error ε based on the capacitance Ctot can be obtained by the following formulas.
ε0=Ctot/2N−C0 (13.1)
ε1=Ctot/2N−C1=Ctot/2N−(C0+E1) (13.2)
εRP=Ctot/2N−CRP (13.3)
εRN=Ctot/2N−CRN (13.4)
ε2=Ctot/2(N−1)−C2 (13.5)
ε3=Ctot/2(N−2)−C3 (13.6)
ε(N−1)=Ctot/22−C(N−1) (13.7)
εN=Ctot/2−CN (13.8)
When these formulas are calculated, the term C0 included in each of the formulas (12) and (13.1) to (13.8) vanishes, and all the errors ε can be represented by E.
The calibration engine 10 obtains the error ε by the formula (13) and stores the obtained error ε in the register 9. After that, the controller 8 corrects the AD conversion result without performing the gain correction using the error ε in the configuration shown in
BLSB={2(M−1)*BLM+2(M−2)*BL(M−1)+ . . . +20*BL1}/2M (14)
In the case of obtaining the error ε in the ADC according to the first embodiment, the values of the formulas (6.1) to (6.7) are obtained based on the lower-order DAC to thereby obtain the values of the formulas (13.1) to (13.8). At this time, when ε0 is large, the effect of the gain error caused by ε0 still exists in the values obtained by the formulas (13.1) to (13.8). To more accurately obtain the values, it is necessary to correct the error. A coefficient GCAL for correcting the gain error at this time can be obtained as follows.
GCAL=(2M=ε0)/2M (15)
Accordingly, true error values can be obtained by multiplying the coefficient GCAL by the formulas (13.1) to (13.8) as shown in the following formulas.
ε0=GCAL{Ctot/2N−C0} (16.1)
ε1=GCAL{Ctot/2N−C1} (16.2)
εRP=GCAL{Ctot/2N−CRP} (16.3)
εRN=GCAL{Ctot/2N−CRN} (16.4)
ε2=GCAL{Ctot/2(N−1)−C2} (16.5)
ε3=GCAL{Ctot/2(N−2)−C3} (16.6)
ε(N−1)=GCAL{Ctot/22−C(N−1)} (16.7)
εN=GCAL{Ctot/2−CN} (16.8)
In this case, the use of ε0 to obtain the coefficient GCAL causes a contradiction in the calculation of the formula (16.1). This contradiction can be solved by the following steps. That is, ε0 in the formula (15) is first calculated using the value of the formula (13.1) including the error, and the coefficient GCAL is calculated by the formula (15). Then, ε0 is obtained by the formula (16.1), and the obtained value of ε0 is input into the formula (15) again, to thereby update the value of the coefficient GCAL. Further, the operation of calculating the formula (16.1) and updating the value of ε0 is repeated a plurality of times, and thus ε0 is obtained recursively.
The error correction is performed to eliminate the gain error by correcting the error ε that is obtained based on the full-scale capacitance. This eliminates the need for gain correction after the correction.
<Operation of ADC During Calibration>
Next, the operation of the ADC 100 during the calculation of the error ε will be described. The operation of the DAC in the ADC 100 during the derivation of the error is basically similar to that disclosed in Non Patent Literature 1. In the derivation of the correction coefficient, the ADC 100 (or the calibration engine) obtains only the values of the formulas (6.1) to (6.7). The derivation of the correction coefficient for the capacitance CN will now be described by way of example.
Qsmp=CN(Vcm−VREF_HIGH)+(C(N−1)+ . . . +C2+C1+C0)(Vcm−VREF_LOW) (17)
Next, in a transition to the successive approximation, the initial comparison code is shifted as shown in
Qconv_1=CN(VNP−VREF_LOW)−(C(N−1)+ . . . +C2+C1+C0)(VNP−VREF_HIGH) (18)
In this case, when the error EN represented by the formula (6.1) is zero, i.e., when there is no error, the relation of Vcm=VNP holds, and the charge during sampling and the charge during comparison have the relation of Qsmp=Qconv_1.
In practice, however, since the EN error is not zero (EN≠0), Vcm is not equal to VNP (Vcm≠VNP). At this time, the successive approximation logic is activated to allow the lower-order DAC to operate to search the code for Vcm=VNP by a binary search. The difference between the code searched at this time and the code used in the initial comparison corresponds to the error EN.
Thus, the errors EN . . . E1 which are respectively expressed by the formulas (6.1) to (6.7) can be obtained by controlling all the capacitances in the same manner, so that the error ε used in the correction can be obtained. The value of the error is calculated in such a manner that a value is acquired a plurality of times until the effects of noise and the like are removed and then averaging processing is performed.
An offset of the comparator 130 poses a problem in the error calculation. A method for canceling the offset will be described below. In the case of deriving the error of the capacitance CN, for example, assuming that an error obtained from the formulas (17) and (18) is represented by EN1 and a conversion error caused due to the offset of the comparator 130 is represented by Eos, the following formula is established.
EN1=EN+Eos (19)
Next, the voltage to be charged during sampling is replaced by the voltage to be charged during successive approximation. As shown in
Qsmp2=CN(Vcm−VREF_LOW)+(C(N−1)+ . . . +C2+C1+C0)(Vcm−VREF_HIGH) (20)
Next, in a transition to the successive approximation, the initial comparison code is shifted as shown in
Qconv_2=CN(VNP−VREF_HIGH)−(C(N−1)+ . . . +C2+C1+C0)(VNP−VREF_LOW) (21)
When the error value obtained at this time is represented by EN2, EN2 is obtained as a difference of the lower-order DAC with respect to VREF_LOW. Since the code is inverted, the polarity of the error EN is inverted. However, the polarity of the error caused due to the offset of the comparator 130 does not change. That is, the following formula is established.
EN2=−EN+Eos (22)
Accordingly, the error value which is not affected by the offset of the comparator 130 can be obtained by subtracting the formula (21) from the formula (19).
EN1−EN2=2EN (23)
While the conversion is repeatedly performed a plurality of times as described above, the error value can be obtained with high accuracy by replacing the code for an even number of conversions by the code for an odd number of conversions and performing the integration and averaging of the formula (23).
<Method for Carrying Out Correction Arithmetic Processing During Successive Approximation Operation for AD Conversion>
As described above, the correction processing after AD conversion is carried out after the conversion is finished. However, when the correction processing is simply performed after the AD conversion is finished, a correction time is added to an AD conversion time, which causes an overhead of processing time (processing speed). The formula (3) shows that the error ε, which is a correction coefficient, is data associated in one-to-one correspondence with the capacitances, i.e., the bits. Further, the successive approximation ADC determines the code in order from the most significant bit. The first embodiment is characterized in that a higher-level code does not change even when the redundant conversion is performed. Therefore, the correction processing can be carried out step by step in a FIFO (First In First Out) manner from the most significant bit, without waiting for the AD conversion of lower-order bits. Thus, the correction processing is completed during the successive approximation operation for AD conversion. This makes it possible to eliminate the overhead of AD conversion time due to the correction processing. In the arithmetic processing, for example, ADOUT and ADERR are subtracted and the resultant values are added in every conversion by an integration circuit, so that the final conversion result ADOUT is obtained.
As shown in
<Advantageous Effects of First Embodiment>
The first embodiment has an advantageous effect that it is possible to obtain a high-accuracy ADC with small elements by calculating a correction coefficient and correcting an error in the local DAC of the successive approximation ADC.
Since the correction in post processing can be carried out by providing the DAC with redundancy, the overhead in successive approximation processing can be eliminated. This leads to an improvement in comparison time. Further, the arithmetic processing based on a power-of-two weight makes it possible to reduce the computation scale. In particular, according to the first embodiment, the provision of the extension DAC having positive and negative polarities enables an improvement in accuracy and processing speed.
For example, when a typical non-binary weight of 1.85 is considered, a multiplier/divider is required every time arithmetic processing of 1.85n is carried out. On the other hand, in the case of a binary weight, when 2n is treated in the calculation, the processing can be performed by a simple bit shift and a correction logic can be configured using only an adder/subtractor, without using a multiplier/divider, which leads to a reduction in area and power consumption.
In a second embodiment, an example of the ADC using the lower-order DAC including a cascade coupling capacitance will be described. The basic configuration of the ADC is similar to that of the first embodiment, except for the lower-order DAC.
The capacitor element C0 is connected to a common node between the capacitor elements CN to C1, CRP, and CRN. The capacitor elements CLM to CL0 are connected in parallel between the switches SLM to SL0 and the capacitor element C0. The switches SLM to SL0 are provided between the capacitor elements CLM to CL0 and each of the input terminal for the ADC analog input signal, the supply terminal for the reference voltage VREF_HIGH, and the supply terminal for the reference voltage VREF_LOW. A switch SC2 is provided between a reference voltage and a common node between the capacitor element C0 and the capacitor elements CLM to CL0. Further, in this example, a node between the capacitor element C1 and the capacitor element CRP is connected to one input terminal (node NP) of the comparator 130.
Assuming herein that a transfer function for obtaining the amount of charge transferred by switching of the capacitances of the capacitor elements CLM to CL1 through the capacitor element C0 is represented by γ, a charge transfer amount QCLM of the capacitor element CLM can be expressed as follows.
|QCLM|=γCLM×|VREF_HIGH−VREF_LOW|=γ2CL0×|VREF_HIGH−VREF_LOW| (24)
Assuming herein that an ideal transfer function γ is represented by γi, γi can be expressed as follows.
However, in the configuration shown in
Cp=αCL0 (26)
Accordingly, since the transfer function γ is affected by the parasitic capacitance, it is necessary to take into consideration α to obtain the correct transfer function. However, the parasitic capacitance is, for example, a wiring parasitic capacitance or a parasitic capacitance of a switch, and is a device different from each capacitor element of the DAC. This makes it difficult to obtain a ratio with high accuracy. For this reason, it has been difficult to configure a circuit using the cascade coupling capacitance which enables high-speed switching as the lower-order DAC constituting the ADC.
An error caused due to the parasitic capacitance of the lower-order DAC using the cascade coupling capacitance can be corrected by a digital correction method according to the second embodiment. In the case of the example shown in
γ2MC0/C1≧1 (28)
When the transfer function γ is equal to or greater than 1, the lower-order DAC 120 can transfer the amount of charge which is larger than the reference capacitance C1 of the higher-order DAC 111, which makes it possible to provide redundancy. Therefore, the DAC having the cascade coupling capacitance configuration eliminates discontinuous portions in the output of the DAC, so that the digital correction can be performed. In this case, it is obvious that the same advantageous effects can be obtained by performing the calibration operation on the capacitances in the same manner as in the first embodiment.
Like in the first embodiment, the ADC shown in
As described above,
The capacitor element C0 is connected to a common node between the capacitor elements CN to C1. The capacitor elements CLM to CL0 are connected in parallel between the switches SL(M+1) to SL0 and the capacitor element C0. The switches SL(M+1) to SL0 are provided between the capacitor elements CLM to CL0 and each of the input terminal for the ADC analog input signal, the supply terminal for the reference voltage VREF_HIGH, and the supply terminal for the reference voltage VREF_LOW. The switch SC2 is provided between the reference voltage and a common node between the capacitor element C0 and the capacitor elements CLM to CL0.
The capacitor element CRN is connected to the common node between the capacitor elements CN to C1. The capacitor element CRNL is provided between the switch SLN and the capacitor element CRN. The switch SLN is provided between the capacitor element CRNL and each of the supply terminal for the reference voltage VREF_HIGH and the supply terminal for the reference voltage VREF_LOW. A switch SC3 is provided between the reference voltage and a common node between the capacitor elements CRN and CRNL. In this example, a node between the capacitor element C1 and the capacitor elements C0 and CRN is connected to one input terminal (node NP) of the comparator 130.
Assuming herein that the transfer function for obtaining the amount of charge transferred by switching of the capacitances of the capacitor elements CLM to CL1 through the capacitor element C0 is represented by γ, the charge transfer amount QCLM of the capacitor CLM can be expressed in the same manner as the formula (24).
|QCLM|=γCLM×|VREF_HIGH−VREF_LOW|=γ2M−1×|VREF_HIGH−VREF_LOW| (29)
In this case, the formula for γi representing the ideal transfer function γ is the same as the formula (25), and the relation between the transfer function and the parasitic capacitance connected to the node NP2 is the same as the relation expressed by the formula (27) using α. The transfer function γ has the same constraint as that in the formula (28).
As the value of the transfer function γ increases, the redundancy increases. For example, in the case of γ2MC0/C1=2, the redundancy corresponding to the capacitance C0 of the higher-order DAC 111 is provided. However, the resolution of the lower-order DAC 120 is reduced by one bit. The negative-polarity-side extension DAC may be configured in the same manner as the capacitance C0. Assuming that a transfer function to be transmitted to the node NP through the capacitor element CRN is represented by γ′, it is necessary to satisfy the following relation to ensure a continuous output of analog values from the DAC.
γ≧γ′ (30)
The error ε, which is a correction coefficient, can be calculated by a method similar to that of the first embodiment. The capacitance C0 in the first embodiment can be substituted as follows.
C0→2MγCL0 (31)
CRN→2Mγ′CL0 (32)
At this time, the method for deriving the error value of the capacitance in the first embodiment is changed as follows. For example, in the successive approximation conversion result ADPRE before correction as expressed by the formula (1), the term of BRP vanishes, and the following formula is obtained.
ADPRE=2(N−1+M)*BN+2(N−2+M)*B(N−1)+ . . . +2(1+M)*B2+2M*B1−2M*BRN+2(N−1)*BLM+ . . . +20*BL1 (33)
Similarly, the error correction value ADERR can be expressed as follows.
ADERR=εN*BN+ε(N−1)*B(N−1)+ . . . +ε2*B2+ε1*B1−εRN*BRN+ε0*(BLSB) (34)
The error ε based on the capacitance C0 can be expressed by formulas (8.1) to (8.5) and (8.7) in the same manner as in the first embodiment. The formulas in the second embodiment differ from the formulas in the first embodiment in that the term of εRP is not required.
ε1=C0−C1=−E1 (8.1)
ε2=2C0−C2=−(E1+E2) (8.2)
ε3=4C0−C3=−(2E1+E2+E3) (8.3)
ε4=8C0−C4=−(4E1+2E2+E3+E4) (8.4)
εN=2(N−1)*C0−CN=−(2(N−2)E1+2(N−3)E2+2(N−4)E3+ . . . +2E(N−2)+E(N−1)+EN) (8.5)
εRN=C0−CRN=−ERN (8.7)
The error ε is obtained by the above formulas and the obtained error ε is stored in the register 9, which makes it possible to correct the AD conversion result in the circuit shown in
ADERR=εN*BN+ε(N−1)*B(N−1)+ . . . +ε2*B2+ε1*B1−εRN*BRN (35)
The calculation of the error based on the full-scale capacitance can be performed in the same manner as in the first embodiment. The error correction value ADERR is the same as that expressed by the formula (34). In this case, εRP is not required, and thus the calculations of the formulas (13.3) and (16.3) are not required.
Similarly to the first embodiment and
As described above, even when the ADC of the first embodiment is configured using the cascade coupling capacitance configuration, a high accuracy and an improvement in processing speed can be achieved, like in the first embodiment.
In a third embodiment, a configuration example of a comparator offset cancel circuit used during derivation of an error will be described. The components of the third embodiment other than the offset cancel circuit are similar to those of the first and second embodiments.
In the example shown in
In this manner, the offset of the comparator can be reduced by the comparator offset cancel circuit provided in the configurations of the first and second embodiments, which leads to a further improvement in the accuracy of AD conversion.
The invention made by the present inventors has been described in detail above. However, the present invention is not limited to the embodiments described above and can be modified in various ways without departing from the scope of the invention.
The first to third embodiments can be combined as desirable by one of ordinary skill in the art.
While the invention has been described in terms of several embodiments, those skilled in the art will recognize that the invention can be practiced with various modifications within the spirit and scope of the appended claims and the invention is not limited to the examples described above.
Further, the scope of the claims is not limited by the embodiments described above.
Furthermore, it is noted that, Applicant's intent is to encompass equivalents of all claim elements, even if amended later during prosecution.
Number | Date | Country | Kind |
---|---|---|---|
2015-168502 | Aug 2015 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4415882 | Akazawa | Nov 1983 | A |
4764750 | Kawada | Aug 1988 | A |
4970514 | Draxelmayr | Nov 1990 | A |
7038609 | Hurrell | May 2006 | B1 |
7218259 | Hurrell et al. | May 2007 | B2 |
7605741 | Hurrell | Oct 2009 | B2 |
20060021491 | Greco | Feb 2006 | A1 |
20080036641 | Confalonieri | Feb 2008 | A1 |
20110109488 | Nakajima | May 2011 | A1 |
20140285370 | Miki | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
5-167449 | Jul 1993 | JP |
3224808 | Nov 2001 | JP |
4806021 | Nov 2011 | JP |
4890561 | Mar 2012 | JP |
5565169 | Aug 2014 | JP |
Entry |
---|
Lee, H. et al., “A Self-Calibrating 15bit CMOS A/D Converter”, IEEE Solid State Circuits, vol. 19, No. 6. Dec. 1984. |
Nakane, H. et al., “A Fully Integrated SAR ADC Using Digital Correction Technique for Triple-Mode Mobile”, ASSCC, Session 5-2, Nov. 2013. |