METHOD OF CALIBRATING A SAR A/D CONVERTER AND SAR-A/D CONVERTER IMPLEMENTING SAID METHOD
The present disclosure relates to a method of self-calibration of a successive approximation register-analog-to-digital converter. The method includes measuring an error value for each thermometer element of a plurality of thermometer elements and determining a mean value of measured error values. The method also includes generating a thermometer scale where each level of the thermometer scale will be an incremental sum of each value of a first subset, and each further level of the thermometer scale will be a sum of all values of a second subset plus the incremental sum of the elements of the first subset in any order. In addition, the method includes generating the output code according to the thermometer scale.
The present disclosure relates to a method of self-calibration of a successive approximation register-analog-to-digital (SAR-A/D) converter and a SAR-A/D converter implementing the method. Particularly, the present disclosure relates to a method of self-calibration of a mixed thermometer code-binary code SAR-A/D converter and to such mixed thermometer code-binary code SAR-A/D converter. More particularly, the present disclosure relates to a method of self-calibration of the digital-to-analog converter DAC that is part of the thermometer-code SAR-A/D converter to optimize the integral non-linearity of the analog-to-digital converter.
BACKGROUNDSAR A/D converters are known in the art to be used for analog-to-digital conversion. In this type of converter, conversion is based on a dichotomic search through all possible quantization levels to the determination of the final conversion value.
Referring to
Particularly, binary-weighted physical elements are usually employed in the internal DAC to carry out the conversion process. For example, these binary-weighted physical elements consist of resistors, capacitors, current generators and the like.
In order to convert a voltage corresponding to the binary code ‘101001’ (i.e. the code representing the number 41) using a binary converter having a number Nbit=NBitBin of bits equal to six, six physical elements are available. In the binary code ‘101001’ the physical elements corresponding to the indices 0, 3 and 5 (i.e. the ones of the binary code ‘101001’) are intended to be somehow selected and the corresponding converted voltage is 41/64 Vref, where Vref represents the reference voltage to be used for the conversion process.
However, if a thermometer-code SAR A/D converter is used, all the physical elements are nominally equal to one another. Therefore, during the conversion process, if the voltage corresponding to the binary code ‘101001’ (41) has to be converted using a thermometer-code converter having a number Nbit=NBitTh of bits equal to six, all the physical elements, equal to 64 (because 2̂6=64), corresponding to the indices from 0 to 40 are selected (whereas the physical elements corresponding to the indices from 41 to 63 are not selected) and the corresponding converted voltage is always equal to 41/64 Vref.
Conversely, in a converter having a mixed thermometer-code and binary design, the plurality of physical elements that form the converter are divided into two subsets, i.e. one subset formed by thermometer elements and the other subset formed by binary-weighted elements.
Namely, the binary-weighted elements define the LSB bits of the output code generated by the converter, whereas the thermometer elements define the MSB bits of such output code.
It shall be noted that the accuracy of the converter with the thermometer-code and binary design is set by the smallest physical element implemented in the binary elements and corresponds to 1 LSB, i.e. the bit corresponding to the zero index of LSB bits.
The example of
binary physical elements are used for indices from 0 to 5, which represent the LSB bits of the output code, which means that the 0 index is given by a binary element, the 1 index is given by a binary element having twice the value (of the binary element for the 0 index), the 2 index is given by a binary element having four times the value (of the binary element for the 0 index) and so on; and
thermometer elements are used for indexes from 6 to 11, which represent the MSB bits of the output code, such that each index involves the addition of as many thermometer elements as required by the binary coding of the index weight minus 6 (2(bit index−6)).
The problematic aspect of such thermometer-code ADC is that, as the latter generates the values of the various voltages Vthermo (Thermo=0 . . . 2NTh) of the thermometer levels as used in the A/D conversion process, these voltage values VThermo are affected by the problem that the thermometer elements are not identical, as they should ideally be but actually exhibit non-idealities, which introduce an error in such voltage values VThermo.
Thus, assuming that 64 thermometer elements Tj are provided, the ideal voltages VThermo required during SAR conversion are:
where Ttot is the total value of the thermometer elements, Thermo belongs to the set from 0 to 64 and Tj belongs to the set T0, . . . , TThermo−1, because voltage levels are one more than the elements. Nevertheless, since all thermometer elements Tj are imperfect, each having its own error τj, then each thermometer element may be rewritten according to the formula:
Tj=Tideal+τj
In view of the above, the real voltage values Vthermo required during SAR conversion are expressed by the following formula:
Thus, the INL error between the ideal and real voltage sequences may be expressed by the following formula:
where INLThermo represents the error for the Thermoth level of the DAC converter.
Such INLThermo depends on the order of thermometer-code errors and is inherently equal to zero for minimum and maximum voltage limits Vmin=0 and Vmax=Vref=V64 (because in this case the number of bits is supposed to be 6).
The INLThermo value is affected by the measurements of the imperfection of the thermometer elements. Particularly, the calibration process as disclosed in Patent Application MI2014A000720 (which is intended to be integrated in the present disclosure), was found to be able to approximate the ideal characteristic INL with an accuracy of half the DNL error of the worst measured thermometer element.
Of course, the INLThermo value is invalidated if measurements on thermometer elements are not made with the utmost accuracy.
A further problem is the area occupied by the switches that are used to switch the thermometer elements on.
SUMMARYThe object of the present invention is to provide a method and a converter for self-calibration of a hybrid thermometer-binary code SAR A/D converter.
One embodiment provides a more efficient method of self-calibration of a thermometer-code SAR A/D converter that does not require the introduction of dedicated hardware.
The characteristics and advantages of the present disclosure will appear from the following detailed description of a possible practical embodiment, illustrated as a non-limiting example in the set of drawings, in which:
Even when this is not expressly stated, the individual features as described with reference to the particular embodiments shall be intended as auxiliary to and/or interchangeable with other features described with reference to other exemplary embodiments.
Parts that have been described with reference to the prior art will be designated hereinbelow, for simplicity, by the same numerals.
In view of minimizing the INLThermo value without using dedicated or additional hardware, the redundancy in the actuation sequence of the thermometer elements Tj is a key factor for efficient self-calibration of the SAR A/D converter.
Particularly, all the actuation sequences are equivalent (because all the elements must be identical, i.e. 64 LSB when NBitBin bit is equal to 6), but they are slightly different in practice, whereby any change in the actuation sequence of the elements involves a change in the output code of the ADC.
As mentioned above, the error between the ideal and real voltage sequences may be expressed by the following formula:
In order to minimize such INLThermo value a method for calibration of the SAR-A/D converter is provided.
Particularly, also referring to
In one aspect, the digital-to-analog converter DAC comprises a plurality of thermometer elements Tj, block 1, and a plurality of binary-weighted elements, block 2.
It shall be noted that, in the definition of the present calibration method, the binary part of the physical elements is assumed to be perfect, i.e. error-free and designed in optimized fashion with the available hardware technologies.
Such binary part is used for high-precision measurement of the errors Ej of the thermometer elements Tj, possibly by means of averaging methods.
Particularly, relative differences Ej may be measured using a first subconverter CLSB having a few bits, as the measured difference is between numbers that should have been ideally identical, but are actually similar and not coincident.
For this purpose, a first subset of thermometer elements Tj is designed to be obtained, block 3, from the plurality of physical elements of the converter, such first subset defining the MSB bits of the output code OUTPUT and a second subset of binary weighted elements Nbin is also designed to be obtained, block 4, such second subset Nbin defining the LSB bits of the output code OUTPUT.
In one aspect, the output code OUTPUT is defined by a thermometer scale STh whose number of levels mi, is equal to 2NBitTh, 2NBitTh being equal to NTh.
Advantageously, the method includes a step 5 of measuring the error value of each thermometer element Tj, which is carried out with methods known to the skilled person and not described herein.
Once the error value of each thermometer element is measured, in one aspect of the method, a step is provided, block 6, for determining a mean value μ of these measured values.
When the mean value μ is known, in one aspect of the method, at block 7 the plurality NTh of thermometer elements Tj are divided into a first subset X and a second subset Y, each containing an identical number of values x, y.
Particularly, the number of elements x, y in the subsets X and Y is half the number of the thermometer elements Tj. This division is made, for instance, using a software algorithm.
This is possible because the following equation is by definition always true, regardless of the measured thermometer element values:
As a result of this equality, when the thermometer elements Tj are divided into the above two subsets X and Y, then:
i.e.:
This means that the sum of the thermometer elements x of the subset X (i.e. the INL of the subset X) is equal to the opposite of the sum of the thermometer elements y of the subset Y (i.e. the INL of the subset Y), regardless of the type of partition.
Assuming the above, then the first subset X comprises the thermometer elements Tj whose values are closer to said mean value μ as long as the error of the sum of thermometer elements Tj of the first subset X is not more than the error value of the element farthest from the mean value μ. The second subset Y comprises all the remaining thermometer elements Tj.
The allocation of the respective s values to the subset X or the subset Y is performed, for instance, by a software algorithm.
The method of the present invention includes, at step 8, generating a thermometer scale STh, using for:
each level mi of said thermometer scale STh, with i ranging from 0 to NTh/2, the incremental sum of each value x of said first ordered subset X; and
each further level mi of said thermometer scale STh, with i ranging from NTh/2+1 to NTh, the sum of all the values y of said second subset Y plus the incremental sum of the elements x of the subset X in any order.
The method also includes generating, at block 9, the output code OUTPUT according to such thermometer scale STh.
In a preferred aspect of the method, the first subset X is ordered such that the maximum error value εR of the integral non-linearity error INL of a Rth thermometer level may be reduced and minimized.
Preferably, in the present method, each further level mi of the thermometer scale STh, with i ranging from NTh/2+1 to NTh, will be the sum of all the values y of the second subset Y plus the incremental sum of the elements x of the subset X in reverse order.
In other words, also referring to
Namely, assuming that:
the number of thermometer bits NBitTh is equal to three, then the number Nth of thermometer elements Tj is equal to eight (23 being equal to 8) such that the number of levels mi of the thermometer scale STh is also equal to eight,
the number of binary bits NBitBin is equal to three, then the number NBin of binary elements is equal to three such that the number of levels of the binary scale SBin is also equal to eight,
then, the output code OUTPUT is defined by the thermometer scale STh having a number of levels mi equal to eight, and by the binary scale SBIN having a number of levels equal to eight.
If this is the case, assuming that the measured values of the Nth=8 thermometer elements Tj of the thermometer scale STh are, for instance, equal to T1=0.7, T2=0.9, T3=1.2, T4=1.1, T5=1.3, T6=0.8, T7=0.9 and T8=1.4, then the step of calculating the mean value μ provides a value of 1.0375, although the ideal value should have been 1.0.
Once the mean value μ is known, the subset X, after the above mentioned division step, comprises a number s of values equal to four, i.e. half the Nth=8 thermometer elements Tj, such values being the ones closer to the mean value μ, whereas the subset Y, which also comprises a number s of values equal to four, i.e. half the Nth=8 thermometer elements Tj, is filled with the values that are farther from the mean value μ.
In other words, the subset X comprises four elements x1, x2, x3, x4, and the subset Y also comprises four elements y1, y2, y3, y4, each identifying its own value Tj.
It shall be noted that the values x1, . . . , 4 of the subset X are used individually, whereas the values y1, . . . , 4 of the subset Y are used as a group, i.e. as a single value equal to the sum of the four values y1, . . . , 4.
Once the two subsets X and Y have been defined, then a new thermometer scale STh may be generated, such that each level from m1 to m4 of the thermometer scale STh is associated with the incremental sum of the available values x1, . . . , 4 of the first subset X.
Particularly, the incremental sum of each value x of the first subset X is equal to
where k ranges from 0 to Nth/2 and xj represents each value stored in such first subset X.
Therefore, the term incremental sum of the values x1, . . . , 4 is intended to mean the following:
position m0 of STH=0;
position m1 of STH=value x1;
position m2 of STH=value x1+value x2;
position m3 of STH=value x1+value x2+value x3;
position m4 of STH=value x1+value x2+value x3+value x4.
In other words:
for the first level m1 of the thermometer scale STh there is a single value of the subset X, particularly the one stored in the first position x1,
-
- for the second level m2 of the thermometer scale STh there is the sum of the values stored in the first position x1 and the second position x2 of the subset X, and
- for the third level m3 of the thermometer scale STh there is the sum of the values stored in the first position x1, the second position x2 and the third position x3 of the subset X.
Each further level from m5 to m8 of the thermometer scale STh is associated with the sum of all the values y1, . . . , 4 of the second subset Y plus the incremental sum of the elements x of the subset X in reverse order.
Namely:
the level m5 of the thermometer scale STh is equal to the sum of all the values y1, . . . , 4 of the second subset Y plus the value of the level x4 of the first subset X,
-
- the level m6 of the thermometer scale STh is equal to the sum of all the values y1, . . . , 4 of the second subset Y plus the value of the levels x4 and x3 of the first subset X,
- the level m7 of the thermometer scale STh is equal to the sum of all the values y1, . . . , 4 of the second subset Y plus the value of the levels x4, x3 and x2 of the first subset X, and
- the level m8 of the thermometer scale STh is equal to the sum of all the values y1, . . . , 4 of the second subset Y plus the value of the levels x4, x3, x2 and x1 of the first subset X.
According to a preferred embodiment of the present method, if the sum of the errors of the elements x of the first subset X is greater than the highest error of the individual elements x, then a step is provided of exchanging at least one value y of said second subset Y with an appropriate element x of said first subset X if the sum of the resulting elements is smaller than the worst of the elements of the new subset X resulting from the exchange.
For example, assuming that the measurement of the error value of each thermometer element Tj has provided the following values 0.97 0.93 0.85 0.98 1.1 1.2 1.02 1.05 and that the mean value, i.e. the ideal element, is 1.0125, then the DNL of each element is −0.0420, −0.0815, −0.1605, −0.0321, 0.0864, 0.1852, 0.0074 and 0.0370.
Ordered DNLs are obtained by ordering, i.e. −0.1605, −0.0815, −0.0420, −0.0321, 0.0074, 0.0370, 0.0864 and 0.1852.
The selection of GOOD elements, i.e. those whose values are closer to the mean value μ gives elements with values −0.0420, −0.0321, 0.0074 and 0.0370 whereas the selection of BAD elements, i.e. those whose values are farther from the mean value i, gives elements with values −0.1605, −0.0815, 0.0864 and 0.1852.
The sum of GOOD elements is −0.0296, whereas the sum of BAD elements is 0.0296.
Therefore, here the DNL at half-scale is −0.0593, which is worse than all the DNLs of the GOOD elements.
Thus, an alternative selection of GOOD elements is required, with one GOOD element being exchanged with a BAD element, e.g. the third BAD element being selected instead of the fourth GOOD element, i.e.:
-
- −0.0420 −0.0321 0.0074 0.0864
The same applies for the selection of BAD elements,
-
- −0.1605 −0.0815 0.1852 0.0370
The INL at half-scale, which is equal to 0.0395, is found to be better than any DNL of the new GOOD elements.
This exchange provides advantages, such as making the sum of the so-called GOOD elements as close as possible to that of the so-called BAD elements, without causing the GOOD (or BAD) elements to include an element that is too far from the mean value. In fact, since the two sums are opposite to each other, it would be ideally desirable (although not achievable in practice) that both sums should be zero (i.e. that the INL characteristic at half-scale should be perfect).
In one aspect of the present disclosure, the first subset X is ordered such that the maximum error value εR of the integral non-linearity error (INL) of a Rth thermometer level may be minimized.
In order to minimize the integral non-linearity error value (εR INL), in one aspect as disclosed in MI2014A000720, which is intended to be incorporated in the present disclosure, the method includes:
determining the error value εR, (block 5), using the following formula:
where Ej represents the relative mismatch differences between the plurality of thermometer elements Tj and a reference thermometer element Tref selected from said plurality of thermometer elements Tj and R ranges from 0 to NTh and represents the number of available thermometer levels.
In one aspect, the relative mismatch differences Ej may be measured using the following formula:
where:
NTh represents the number of thermometer elements 2NBitTh; and
Ttot is the total value of said plurality of thermometer elements Tj, which total value Ttot may be calculated using the following formula:
The mathematical proof of the above formulas may be found in
Particularly, the
The differential non linearity value (DNL) may be determined (block 5) using the following formula:
In one aspect, the errors Ej of the thermometer elements Tj may be possibly measured by also using averaging methods.
In one aspect, in order to measure the mismatch Ej of the thermometer elements Tj, if these thermometer elements Tj are implemented as capacitors C (see
where ΣC represents the sum of the thermometer elements, Cthref is a reference thermometer element, CthX is the thermometer element being measured, VrefP is a first reference voltage that is found on the reference thermometer element during sampling and on the element being measured during the step of checking, VrefN is a second reference voltage that is found on the thermometer element being measured during sampling and on the reference element during the step of checking, and on all the other thermometer elements throughout the conversion and ΔV is the measurement of the errors Ej.
The above identified error INLR may be minimized by determining the appropriate actuation permutation P of the thermometer elements Tj for more accurate calibration.
For this purpose, the above mentioned method step of minimizing or reducing the maximum of said integral non-linearity INL error value INLR of the Rth thermometer level, includes:
identifying the maximum of said error value INLR for each level R;
recalculating the integral non-linearity error value INLR for a number of permutations P defined beforehand; and
selecting the permutation that reduces or minimizes said error value INLR from said number P of permutations.
Nevertheless, although this minimization step is effective, there still exist an excessively high number of permutations to be processed by the method, i.e., theoretically corresponding to the factorial of the number of thermometer elements, e.g. 64 in the case of a 6-bit thermometer-code converter.
Therefore the maximum absolute error INLR must be minimized without processing the 64 permutations to actuate the thermometer elements.
This may be done, for example, using a metaheuristic algorithm, such as a simulated annealing algorithm, a tabu search algorithm or genetic algorithm but also, preferably, using a deterministic approach.
In view of using a deterministic approach it should be noted that, for a “perfect” DAC converter, each thermometer element Tj must have a “perfect” value, i.e. Tideal.
If this is not the case (i.e. if the converter is not perfect), each time that the thermometer element TThermo is added, the INL error should change by τThermo.
In fact, each thermometer element is affected by an error defined as DNLThermo which represents, as is also shown from
In the light of the above, assuming a Gaussian arrangement of the thermometer elements Tj centered about their mean value (with the mean value being, by definition, Tideal) which means that many thermometer elements Tj should be close to the mean value, to have a small DNL error, and with the start and end points of the INL characteristic error being zero, a thermometer-code sequence very close to the optimal sequence may be “constructed”.
For this purpose, the element with the greatest DNL error must be identified and centered on the ideal INL characteristic or, in an equivalent manner, its DNLworst must be centered at zero.
Particularly, in a preferred aspect, the method provides an adequately accurate approximation (from 0 or the end-of-scale value) of ½ of the DNL error (with opposite sign) of the worst thermometer element, using the elements of the thermometer set having the smallest DNL error.
It shall be noted that an INL error of ±½ DNLworst should never be exceeded when constructing the INL characteristic.
Once the worst thermometer element is determined and centered with respect to the Integral Non-Linearity INL characteristic, the second worst element is determined by repeating the procedure, but not starting from 0 (or the end-of-scale value), but from the position defined by the last determined element (the worst element). This will provide the best possible INL performances for this particular DAC.
Particularly, the differential non-linearity DNL error value DNLj should be calculated for each thermometer element Tj, and the thermometer element Tj′ with the highest differential non-linearity DNL error value DNLj′ should be selected.
Once the thermometer element Tj′ with the highest error value DNLj′ has been determined, such error value DNLj′ is centered with respect to the ideal conversion characteristic of the converter.
Once such value DNLj′ has been positioned, and in order to reach the value represented by the ideal characteristic, the smallest Differential Non-Linearity DNL error values DNLj of said plurality of thermometer elements are summed until half the value of said thermometer element Tj′ is approximated.
Then, selecting the thermometer element having the highest differential non-linearity DNL error value from the remaining thermometer elements of said plurality of thermometer elements Tj is repeated.
These steps are iterated as many times as there are thermometer elements left, by repeating the selection of the element with the highest differential non-linearity DNL error value DNLj from the remaining thermometer elements Tj and centering its error value DNLj with respect to said ideal characteristic, starting from the position defined by the last determined element.
With the above described method, a value of a kth level of the DAC is given by:
This is advantageous because the output code OUTPUT is generated using the thermometer elements that are closer to the mean value μ, i.e. those of the subset X, as numerators, whereas the thermometer elements that are farther from the mean value are used as denominators.
The above method advantageously provides a process for self-calibration of the SAR-A/D converter which does not require the use of external hardware or other circuit implementations (i.e. on elements that are part of the converter itself), but using the plurality of thermometer elements themselves, and particularly utilizing the binary part for high-accuracy measurement of the errors Ej of the thermometer elements Tj.
It should be particularly noted that the binary part of the converter has a small dynamic range but is inherently accurate due to the hardware implementation of binary elements.
Referring now to
Particularly,
Referring now to
Advantageously, according to the present disclosure, the number of the thermometer elements of the first subconverter CMSB is 2NBitTh and the number of the binary-weighted elements of the second subconverter CLSB is NBitBin.
In other words, in order to implement the above method, the first subconverter CMSB will comprise a number of thermometer elements equal to 2̂NbitTh, whereas in the prior art it would have been (2̂NbitTh)−1.
Therefore, if there are six thermometer-code bits, the number of thermometer elements that would be used in the prior art would equal to 63 physical elements, whereas in this invention it equals 64 physical elements.
The two subconverters CMSB and CLSB, are coupled by an appropriate coupling circuit Cblock.
The coupling circuit Cblock consists, for instance, in a simple wire or a bridge associated with an attenuator capacitor, although a more complex implementation may be also envisaged, and is required to provide the proper scale relationship between the voltages generated by the two subconverters made of capacitors CMSB and CLSB.
Particularly, the subconverter CMSB includes as many capacitors as there are thermometer elements, in this case 64, whereas the subconverter CLSB includes as many capacitors as there are binary elements, in this case 6.
In order to minimize the switch area, the converter is designed to comprise first selector S1 which is configured to select a first group G1 of said plurality of thermometer elements Tj and second selector S2 which is configured to select a second group G2 of the plurality NTh of thermometer elements Tj.
The first selector S1 comprises a plurality of selector switches IG1j, each in signal communication with a respective thermometer element Tj of the first group G1, which means that each thermometer element may be controlled by a respective switch to a voltage VrefN and VrefP, where VrefP is the positive reference (typically VDD) and VrefN is the negative reference (typically the ground or GND).
The second selector S2 comprises a single selector switch IG2 in signal communication with the thermometer elements Tj of the second group G2 to control all of them at the same time or as a single block. Therefore, this second group G2 of thermometer element can be controlled by the switch IG2 to a voltage VrefN and VrefP, where VrefP is the positive reference (typically VDD) and VrefN is the negative reference (typically the ground or GND).
Preferably, the group G1 comprises a number of thermometer elements that is greater than half the total thermometer elements, whereas the second group G2 comprises the remaining thermometer elements.
For example, assuming a number of 64 thermometer elements (and hence a 6-bit DAC for the thermometer code part), the group G1 comprises 40 thermometer elements (40 being greater than 64/2) and the group G2 comprises 24 elements (because 64 minus 40 is 24).
Particularly, the 40 thermometer elements of the group G1 are controlled individually, whereas the 24 thermometer elements of the group G2 are controlled together or as a single block, whereby 23 switches will be eliminated and the switch area will be reduced.
Assuming the above, a new set of thermometer elements G3 shall be identified, which is composed by the combination of the group G2 and a subset G1′ of the group G1, which is identified by a program stored in a memory.
For example, the subset G1′ shall comprise eight thermometer elements (G1′=8), in this example 32.
Generally, the subset G1′ is equal to the number Nth/2 minus the number of elements of the group G2.
The remaining unit elements G1″ of the group G1, i.e. the thermometer elements of G1 minus those of the subset G1′ will represent the subset X.
With the above numbers, the remaining thermometer elements G1″ which represent the subset X are thirty-two (i.e. Nth/2). The unit thermometer elements of the subset G1′, that are included in the subset G3 (G2+G1′) have been selected according to the following rules:
removing the worst thermometer elements of the set G1, i.e. the thermometer elements whose values are farthest from the mean value; and
minimizing the difference between the set G1″ and the set G3.
The value of the set G2 is measured by:
measuring all the unit elements; and
measuring the value of the set G2 with respect to any set of unit elements, said set of unit elements having the same nominal total size as G2 and a known error. This measurement may be used to readily assess the value of the large element G2 by comparison with a known set of elements.
Those skilled in the art will obviously appreciate that a number of changes and variants may be made to the method of self-calibration of a SAR-A/D converter as described above to fulfill particular requirements, without departure from the scope of the invention, as defined in the following claims.
Claims
1-15. (canceled)
16. A method of self-calibration of a successive approximation register-analog to digital (SAR-A/D) converter comprising an N-bit digital-to-analog converter for outputting an N-bit output code, the digital-to-analog converter comprising a first subconverter having a plurality (NTh) of thermometer elements and a second subconverter having a plurality of binary-weighted elements NBin, the output code defined by a thermometer scale having a number of levels equal to NTh, the method comprising:
- measuring, for each thermometer element of the plurality of thermometer elements, an error value;
- determining a mean value of the error values;
- dividing the plurality of thermometer elements into a first subset (X) and a second subset (Y), each containing an identical number of elements (x, y) equal to NTh/2, wherein the first subset (X) comprises the thermometer elements whose error values are closer to the mean value when a sum of the error values of thermometer elements of the first subset (X) is not more than the error value of the thermometer element farthest from the mean value of the first subset (X), and the second subset (Y) comprises the thermometer elements of the plurality of thermometer elements that are not contained in the first subset (X);
- generating the thermometer scale, wherein each level mi of the thermometer scale, with i ranging from 0 to NTh/2, is an incremental sum of each error value of the first subset (X), each further level mi of the thermometer scale, with i ranging from (NTh/2)+1 to NTh, is the sum of the values of the second subset (Y) plus the incremental sum of the values of the first subset (X); and
- generating the output code according to the thermometer scale.
17. The method according to claim 16, wherein the first subset (X) is ordered to reduce a maximum error value of an integral non-linearity error of an Rth thermometer level.
18. The method according to claim 16, wherein each further level mi of the thermometer scale, with i ranging from (NTh/2)+1 to NTh, is equal to a sum of the error values of the second subset (Y) plus the incremental sum of the error values of the first subset (X) in reverse order.
19. The method according to claim 16, wherein the incremental sum of each error value of the first subset (X) is equal to ∑ 0 J - 1 x k with J ranging from 0 to Nth/2 where xk represents each error value in the first subset (X).
20. The method according to claim 16, wherein if the sum of the error values of the first subset (X) is greater than a highest error of each error value of the first subset (X), then at least one value of the second subset (Y) is exchanged with at least one value of the first subset (X) if the sum of the resulting values is smaller than the highest of the error values of a new subset (X) resulting from the exchange.
21. The method according to claim 17, further comprising: INL R = ∑ j = 0 R - 1 E j - R N Th ∑ j = 0 N Th - 1 E j where Ej represents relative mismatch differences between the plurality of thermometer elements Tj and a reference thermometer element Tref selected from the plurality of thermometer elements Tj of the first subconverter.
- determining an integral non-linearity error value (INLR) of an Rth thermometer level of the thermometer elements Tj according to the formula:
22. The method according to claim 21, wherein the relative mismatch differences Ej of the first subconverter measured according to the formula: E j = T j - T ref T tot, T tot = ∑ k = 0 N Th - 1 T k, T ref ∈ { T 0 … T N Th - 1 } where: T tot = ∑ k = 0 N Th - 1 T k = N Th T ref 1 - ∑ j = 0 j = N Th - 1 E j
- j ranges from 0 to NTh−1 and represents a number of available thermometer elements; and
- Ttot is a total value of the plurality of thermometer elements Tj, which total value Ttot is calculated using the following formula:
23. The method according to claim 21, wherein the SAR-A/D converter comprises a comparator having an input terminal, and the measuring the relative mismatch differences Ej comprises checking an input voltage on the input terminal of the comparator according the formula: Δ V = C th X - C th ref ∑ C * ( VrefP - VrefN )
- where ΣC represents a sum of the thermometer elements, Cthref is a reference thermometer element, CthX is a thermometer element being measured, VrefP is a first reference voltage that is found on the reference thermometer element during sampling and on the thermometer element being measured during the checking, VrefN is a second reference voltage that is found on the thermometer element being measured during sampling and on the reference element during the checking, and on the other thermometer elements throughout the conversion and ΔV is a measurement of the errors Ej.
24. The method according to claim 17, wherein the reducing the maximum of the integral non-linearity error value (INLR) of the Rth thermometer level comprises:
- identifying a maximum of the error value INLR for each level R;
- recalculating the error value INLR for a number of permutations defined beforehand; and
- selecting a permutation that reduces the error value INLR from the number of permutations.
25. The method according to claim 24, wherein the determining the error value INLR for each thermometer level R of the thermometer elements Tj comprises:
- calculating, for each of the plurality of thermometer elements Tj, the differential non-linearity error value;
- selecting the thermometer element having a highest differential non-linearity error value from the plurality of thermometer elements Tj;
- providing an ideal conversion characteristic of a converter;
- using thermometer elements with a smallest differential non-linearity error values of the plurality of thermometer elements until half the error value of the thermometer element is approximated; and
- placing the thermometer element having an error value with respect to the ideal conversion characteristic of the converter.
26. The method according to claim 25, further comprising:
- repeating the selection of the thermometer element having the highest differential non-linearity error value from the remaining thermometer elements of the plurality of thermometer elements Tj.
27. The method according to claim 26, wherein the repeating the selection of the thermometer element having the highest differential non-linearity error value from the remaining thermometer elements of the plurality of thermometer elements Tj is repeated as many times as there are thermometer elements.
28. A method of self-calibration of a successive approximation register-analog to digital converter comprising a digital-to-analog (D/A) converter, the D/A converter comprising a first subconverter having a plurality of thermometer elements, a second subconverter having a plurality of binary-weighted elements, a first selector having a plurality of switches, and a second selector having at least one switch, the method comprising:
- measuring, for each thermometer element of the plurality of thermometer elements, an error value;
- determining a mean value of the error values;
- operating the first selector to select a first group of the plurality of thermometer elements whose error values are closer to the mean value when a sum of the error values of the thermometer elements of the first group is not more than the error value of the thermometer element farthest from the mean value of the first group; and
- operating the second selector to select a second group of the plurality of thermometer elements that are not contained in the first group.
29. The method according to claim 28, wherein the first group comprises a number of thermometer elements that is greater than the number of thermometer elements contained in the second group.
30. The method according to claim 28, wherein a number of the thermometer elements of the first subconverter is 2̂(number of thermometer bits), and a number of the binary-weighted elements of the second subconverter is equal to a number of binary bits.
31. A digital-to-analog (D/A) converter comprising:
- a first subconverter having a plurality of thermometer elements and configured to determine a mean value of error values of the plurality of thermometer elements;
- a second subconverter having a plurality of binary-weighted elements;
- a first selector configured to select a first group of said plurality of thermometer elements whose error values are closer to the mean value when a sum of the error values of the thermometer elements of the first group is not more than the error value of the thermometer element farthest from the mean value of the first group;
- a second selector configured to select a second group of said plurality of thermometer elements;
- said first selector comprising a plurality of selector switches each coupled with a respective thermometer element of said first group; and
- said second selector comprising at least one selector switch coupled with the thermometer elements of said second group.
32. The D/A converter according to claim 31, wherein said first group comprises a number of thermometer elements that is greater than the number of thermometer elements contained in said second group.
33. The D/A converter according to claim 31, wherein a number of said thermometer elements of said first subconverter is 2̂(number of thermometer bits), and a number of the binary-weighted elements of the second subconverter is equal to a number of binary bits.
Type: Application
Filed: Aug 25, 2015
Publication Date: May 26, 2016
Inventors: Carmelo BURGIO (Bergamo), Mauro GIACOMINI (Bergamo (BG))
Application Number: 14/835,110