IMPROVING DAC INTEGRAL NONLINEARITY (INL) THROUGH GAIN CORRECTION Onur Ozbek, Electrical Design Engineer Staff, Cypress Semiconductor Corp. The static absolute accuracy of a Digital-to-Analog converter (DAC) can be described in terms of three fundamental kinds of errors: offset, gain error, and nonlinearity. Linearity errors are the most challenging to handle of the three since, in many applications, the user can null out the offset and gain errors or compensate for them by building end-point auto calibration into the system design. Linearity errors, however, require more complex correction. A DAC (see Figure-1), converts digital input codes to proportional analog output signals, which could be either current or voltage. The resolution of a DAC refers to the number of unique output levels that the DAC is capable of producing. For 8 example, a DAC with a resolution of 8-bits will be capable of producing 2 (256) different output levels at its output. Ideally, each digital code provides equal analog steps; however, in reality it cannot because of non-idealities. Figure 1. 8-bit DAC Symbol Linearity of a DAC Before jumping into improving the Integral Nonlinearity (INL) of a DAC, it would be best to review how we determine its linearity as shown in Figure-2. In a DAC, we are mostly focused on two measures of its linearity: Differential Nonlinearity (DNL) and Integral Nonlinearity (INL). DNL is the maximum deviation of an actual analog output step, between adjacent input codes, from the ideal step value (Δ). INL is the maximum deviation, at any point in the transfer function, of the actual output level from its ideal value. The ideal value is a straight line drawn between the actual zero and full-scale of the DAC (see Figure-2). Figure 2. DAC Linearity Errors, DNL and INL Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 1 of 6 October 2011 The conventional end-point calibration technique is used to remove gain error in DACs. However, the gain error is typically not linear throughout the full-scale range of the DAC because of various systematic non-idealities in silicon. These systematic patterns may cause unidirectional gradients that result in poor INL performance. The major non-idealities that cause systematic patterns are as follows: Edge Effects, e.g. Length of Diffusion (LOD) Doping gradients Oxide thickness gradients resulting in a threshold shift across die Thermal gradients Voltage drops in the supply lines Therefore, an end-point calibration technique is not enough to remove gain error completely and can result in poor INL performance. Applications that require absolute output accuracy may require a much lower INL. Firmware Technique One way of improving INL performance is using a firmware technique. This technique takes advantage of working with a SoC ® to build two-point auto calibration into the system. For this example, we will use the PSoC 3 family which has up to four multiple-range 8-bit voltage/current DACs with an INL of about 1.5 LSB. The on-chip 20-bit Delta-Sigma Analog to Digital Converter (ADC) has an INL of less than 1 LSB when operating in 12-bit mode. This is more than enough to calibrate 8-bit DAC. The firmware is required to complete a feedback loop between the DAC output and the ADC (see Figure-3). Figure 3. IDAC with ADC Feedback INL typically tends to reach its maximum value in the middle of the full range as shown in Figure-4. If we could bring this peak down, we would improve INL significantly. This observation leads us to use two-point calibration instead of end-point or singlepoint calibration techniques, which by themselves may not be enough to remove gain error completely. The first calibration point will be used to calibrate the first half of the full range (see Equation-1). Similarly, the second calibration point is to calibrate the second half of the full range (see Equation-2). Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 2 of 6 October 2011 DAC Output 2 inGa Ga in -1 Actual Ideal mid 0 max DAC Input Figure 4. DAC Linearity with Different Gain Regions GainCorrection1 = ( 1 DAC (127) − DAC (0) ), Gain1 = Gain1 127 GainCorrection 2 = ( 1 DAC (255) − DAC (127) ), Gain2 = Gain2 128 Equation-1 Equation-2 The algorithm, shown in Figure-5, works as follows. Initially, the two gain correction values are calculated and saved at the mid-point and end-point of digital input DAC values. This is the only time the ADC is used. Therefore, we only sacrifice time for measurement and computation for the calibration once. Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 3 of 6 October 2011 Figure 5. Flow-Chart of the Two-Point Gain Correction Algorithm During normal operation, if a digital code less than the mid-point is passed to the DAC, it is calibrated using the first gain correction value before conversion. If a digital code more than the mid-point is passed to the DAC, it’s calibrated using the second gain correction value before conversion. The calibration will be done on the fly by updating the gain trim registers as shown in Figure-3. A Direct Memory Access (DMA) module would be used if it is available on the SoC to update the registers even faster. Changing the gain correction value in the middle of the full range will create a trim offset (see Equation-3). This trim offset needs to be compensated for in the second half of the range as shown in the algorithm (see Figure-5). TrimOffset = Gain1 − Gain2 * 128 Equation-3 Results For comparison, the INL performance of the 8-bit current DAC (iDAC) with conventional end-point calibration is first measured before the proposed algorithm is applied. The INL was about 1.5 LSB as shown in Figure-6. Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 4 of 6 October 2011 INL of IDAC with Conventional End-Point Gain Correction 0.500 INL(LSB) 0.000 0 32 64 96 128 160 192 224 256 -0.500 -1.000 -1.500 Code Figure 6. INL of IDAC with Conventional End-Point Gain correction After the proposed algorithm is implemented, the INL is now reduced down to 0.8 LSB as shown in Figure-7. INL of IDAC with Two-Point Gain Correction 0.500 INL(LSB) 0.000 0 32 64 96 128 160 192 224 256 -0.500 -1.000 -1.500 Code Figure 7. INL of IDAC with Two-Point Gain correction Conclusion A firmware technique for improving DAC Integral Nonlinearity (INL) in a SoC is described. An implementation example using the PSoC® 3 family and the results are demonstrated. The proposed technique achieved INL improvement of 85% for voltage ® and current DACs in the PSoC 3. Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 5 of 6 October 2011 Cypress Semiconductor 198 Champion Court San Jose, CA 95134-1709 Phone: 408-943-2600 Fax: 408-943-4730 http://www.cypress.com © Cypress Semiconductor Corporation, 2007. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges. PSoC Designer™, Programmable System-on-Chip™, and PSoC Express™ are trademarks and PSoC® is a registered trademark of Cypress Semiconductor Corp. All other trademarks or registered trademarks referenced herein are property of the respective corporations. This Source Code (software and/or firmware) is owned by Cypress Semiconductor Corporation (Cypress) and is protected by and subject to worldwide patent protection (United States and foreign), United States copyright laws and international treaty provisions. Cypress hereby grants to licensee a personal, non-exclusive, non-transferable license to copy, use, modify, create derivative works of, and compile the Cypress Source Code and derivative works for the sole purpose of creating custom software and or firmware in support of licensee product to be used only in conjunction with a Cypress integrated circuit as specified in the applicable agreement. Any reproduction, modification, translation, compilation, or representation of this Source Code except as specified above is prohibited without the express written permission of Cypress. Disclaimer: CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Cypress reserves the right to make changes without further notice to the materials described herein. Cypress does not assume any liability arising out of the application or use of any product or circuit described herein. Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress’ product in a life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges. Use may be limited by and subject to the applicable Cypress software license agreement. Improving DAC Integral Nonlinearity (INL) through Gain Correction Published in Planet Analog (http://www.eetimes.com/design) Page 6 of 6 October 2011