F2810/12 Application Note

ADC Calibration
## Document History:

<table>
<thead>
<tr>
<th>Version</th>
<th>Date</th>
<th>Who</th>
<th>Updates</th>
</tr>
</thead>
</table>

1. Introduction

This application note describes a method for improving the absolute accuracy of the 12-bit ADC found on the F2810/12 devices. Due to inherent gain and offset errors, the absolute accuracy of the ADC is impacted. The methods described in this application note can improve the absolute accuracy of the ADC to achieve levels better then 0.5%.

This application note contains the following sections:

2. Gain & Offset Error Definition
3. Gain & Offset Error Impact
4. Calibration
5. Hardware Connectivity
6. ADC Sampling Techniques
7. Example Software Calibration Driver
8. Useful Tips

This application note is accompanied by an example program that executes from RAM on the F2812 EzDSP.

- ADCcalibration.zip

ATTENTION

The data in this application note is based on observations of ADC behavior on F2810/12 Rev-C TMX devices. More accurate data will be available when full characterization is performed (TMS devices).
2. Gain & Offset Error Definition

An ideal 12-bit ADC with no gain and offset error would be described by equation (1):

\[(1) \quad y = x \times m_i\]

where:
- \(x\) = input count = input voltage \(\times 4095/3.0V\)
- \(y\) = output count
- \(m_i\) = ideal gain = 1.000

The F2810/12 ADC will exhibit gain and offset error defined by equation (2):

\[(2) \quad y = x \times m_a + b\]

where:
- \(m_a\) = actual gain
- \(b\) = actual offset (relative to 0 input)

Gain and offset errors measured on the F2810/12 (Rev-C, TMX) ADC are:

- **Gain Error (\(m_a\)):** < +5\% max \(1.00 < m_a < 1.05\)
- **Offset Error (\(b\)):** < +/-2\% max \(-80 < b < 80\)

**Note:** Most F2810/12 Rev-C TMX devices exhibit positive gain errors of <+3.5\% and offset errors of <+/-1\%. However, some devices exhibit errors above these values reaching the maximum values outlined above. More accurate data will be available when full characterization is performed (TMS devices). To be safe, designers should assume worst case scenario.
3. Gain & Offset Error Impact

Gain and offset errors contribute to errors in the control system. Understanding these errors will enable the user to compensate for these errors in the design.

**Linear Input Range:** The available input voltage range is impacted by the gain and offset errors and the effective resolution is also reduced. The table below summarizes the worst case scenarios:

<table>
<thead>
<tr>
<th>Linear Input Range (Volts)</th>
<th>Linear Output Range (counts)</th>
<th>Input Swing (Volts)</th>
<th>Effective Number Of Bits</th>
<th>mV/Count Resolution</th>
</tr>
</thead>
<tbody>
<tr>
<td>( y = x \cdot 1.00 )</td>
<td>0.000 to 3.000</td>
<td>0 to 4095</td>
<td>1.500 +/-1.500</td>
<td>12.00</td>
</tr>
<tr>
<td>( y = x \cdot 1.05 + 80 )</td>
<td>0.000 to 2.801</td>
<td>80 to 4095</td>
<td>1.415 +/-1.415</td>
<td>11.97</td>
</tr>
<tr>
<td>( y = x \cdot 1.05 - 80 )</td>
<td>0.056 to 2.913</td>
<td>0 to 4095</td>
<td>1.457 +/-1.428</td>
<td>12.00</td>
</tr>
<tr>
<td><strong>Safe Range</strong></td>
<td><strong>0.056 to 2.801</strong></td>
<td><strong>80 to 4095</strong></td>
<td><strong>1.429 +/- 1.372</strong></td>
<td><strong>11.97</strong></td>
</tr>
</tbody>
</table>

The last row in the table, shows the “safe” parameters with which all devices can be guaranteed to operate under. The effective number of bits of the ADC is only slightly reduced (11.9 bits). The reduction in voltage range has a slight impact on external noise sensitivity. The mV/count is reduced from 0.732 to 0.684 which is a 6.6% reduction (or a 6.6% increase in sensitivity over the ideal case).

**Note:** The calibration technique described in this paper will not improve the input range. On future revisions of the devices, an external reference option will be supported which will enable a tighter gain tolerance (< +/-1%). This will significantly reduce the impact of gain error on the input range.

**Bi-Polar Offset Error:** In many applications, the input sensor is a bi-polar input and this needs to be converted to a uni-polar signal before being fed to the ADC. A typical simplified circuit used for this purpose is shown below (ideal ADC case):
Taking into account gain and offset errors and the impact on the input range, the circuit would need to be modified as follows to cater for all possible device characteristics:

The frame of reference for the input offset error has changed. The offset error is measured relative to the bi-polar input when the input value is zero \((x' = 0)\). This corresponds to a uni-polar input value of \(x = 1.43\) V. The inherent ADC gain and offset errors will tend to magnify the error relative to the ideal value.

For example: If we assume the ADC has a +5% gain error and +1% offset error, then the bi-polar offset error count is:

\[
\begin{align*}
\text{Bi-Polar Input:} & \quad x' = 0.00\text{V} \\
\text{Uni-Polar ADC Input:} & \quad x = 1.43\text{V} \\
\text{Expected Count:} & \quad ye = 1.43 \times 4095/3 = 1952 \\
\text{Actual Count:} & \quad ya = 1952 \times 1.05 + 40 = 2090 \\
\text{Bi-Polar Offset Error:} & \quad ya – ye = 2090 – 1952 = 138 \text{ counts (3.3% error)}
\end{align*}
\]

This is a much higher error than a user would otherwise expect. This error can effectively be removed by calibration.
4. Calibration

Calibration is performed by feeding two known reference values into two ADC channels and calculating a calibration gain and offset to compensate the input readings from the other channels. This is possible because the channel-to-channel errors are small. The achievable accuracy using calibration is largely dependant on the accuracy of the known references fed into the ADC. The best possible accuracy achievable is limited by the channel-to-channel gain and offset errors of the ADC.

Note: On Rev-C TMX devices, channel-to-channel gain and offset errors in the order of +/-0.1% have been observed. The exact characteristics will only be available when the devices are fully characterized (TMS devices).

The equations to measure the ADC actual gain and offset and calculate the calibration gain and offset are derived below:

\[ y = x \cdot ma + b \]

\[ ma = \frac{(y_H - y_L)}{(x_H - x_L)} \]

\[ b = y_L - x_L \cdot ma \]

where:
- \( y \) = ADC output
- \( x \) = known reference input
- \( ma \) = actual gain
- \( b \) = actual offset (relative to 0 input)
- \( y_H \) = reference high ADC output
- \( x_H \) = known reference high input
- \( y_L \) = reference low ADC output
- \( x_L \) = known reference low input
- \( ma \) = actual gain
- \( b \) = actual offset
The calibration equation is derived by inverting the input and output of equation (2) describing the ADC actual gain and offset:

\[ y = x \cdot ma + b \]
\[ x = (y - b)/ma \]
\[ x = y/ma - b/ma \]

(5) \[ x = y \cdot \text{CalGain} - \text{CalOffset} \quad \text{CalGain} = 1/ma \]
\[ \text{CalOffset} = b/ma \]

(6) \[ \text{CalGain} = (xH - xL)/(yH - yL) \]
\[ \text{CalOffset} = (yL - xL \cdot ma)/ma \]
\[ \text{CalOffset} = yL/ma - xL \]

(7) \[ \text{CalOffset} = yL \cdot \text{CalGain} - xL \]

In summary, using two known references \((xL, yL)\) and \((xH, yH)\) we can calculate the actual offset and gain error and calculate the calibration gain and offset using the following formulas:

(2) \[ y = x \cdot ma + b \quad \text{ADC actual equation} \]

(3) \[ ma = (yH - yL)/(xH - xL) \quad \text{ADC actual gain} \]

(4) \[ b = yL - xL \cdot ma \quad \text{ADC actual offset} \]

(5) \[ x = y \cdot \text{CalGain} - \text{CalOffset} \quad \text{ADC calibration equation} \]

(6) \[ \text{CalGain} = (xH - xL)/(yH - yL) \quad \text{ADC calibration gain} \]

(7) \[ \text{CalOffset} = yL \cdot \text{CalGain} - xL \quad \text{ADC calibration} \]

The calibration process involves the following four basic steps:

**Step 1**) Read the known reference values input channels \((yL\) and \(yH)\).

**Step 2**) Calculate the calibration gain \((\text{CalGain})\) using equation (6)

**Step 3**) Calculate the calibration offset \((\text{CalOffset})\) using equation (7)

**Step 4**) Cycle through all channels applying the calibration equation (5)
5. Hardware Connectivity

Calibration requires that two ADC channels be dedicated to supply two known reference inputs and this leaves 14 user channels. Recommended connection is shown in Figure 5.1 below:

![Diagram of calibration setup with 16 channels: 2 for calibration and 14 for users.](image)

**Figure 5.1: 2 Channels For Calibration, 14 User Channels**

**Note:** The choice of channels is user selectable. For improved accuracy, references should be connected to channels belonging to the same group. The accuracy of calibration will be largely dependant on the accuracy of the reference voltages and hence the external components used.

If converting a bi-polar input to uni-polar, then a mid-point reference (~1.5V) would be a good choice as one reference input. The other reference input could either be a higher value (~2.5V) or lower value (~0.5V) reference.
For users wishing to retain 16 user channels, the system shown in Figure 5.2 below is recommended. In this scenario, an external analog switch is added which expands the user channels to 16 and is controlled by a GPIO pin using software. In a simple software implementation, the multiplexed channels are sampled on every alternate cycle, relative to the non-multiplexed channels. This means that the multiplexed channels should be used for slower, supervisory type functions. This system leaves the user with 6 channel pairs (if using simultaneous sampling mode) that can be used for critical functions:

![Diagram of 2 Channels For Calibration, 16 User Channels]

**Figure 5.2: 2 Channels For Calibration, 16 User Channels**

**Note:** A buffer is required at the output of the mux (or any high resistance source) to prevent errors due to high source impedance when sampling of the ADC channels.
6. ADC Sampling Techniques

6.1. Sequential Sampling mode

ADC converter on F2810/12 device can operate in sequential sampling mode or simultaneous sampling mode. In sequential sampling mode, ADC samples one channel at a time & then the sampled signal is passed through four stages of ADC pipeline for conversion.

Following diagram shows the timing details of 16-channel conversion (A0-A7 & B0-B7) in sequential mode based on event trigger:

Total Time for converting 16-channels in sequential mode:

\[ T = 17 \times T_{adcclk} + 18 \times (1 + ACQPS) \times T_{adcclk} \]

Following table shows the conversion time required to convert all 16-channels in sequential sampling mode under different ADC clock frequency & S/H window:

<table>
<thead>
<tr>
<th>ACQPS</th>
<th>Number Of Tadcclk Periods</th>
<th>( T ) in us (ADCCLK=25Mhz)</th>
<th>( T ) in us (ADCCLK=12.5Mhz)</th>
<th>( T ) in us (ADCCLK=6.25Mhz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>35</td>
<td>1.4</td>
<td>2.8</td>
<td>5.6</td>
</tr>
<tr>
<td>3</td>
<td>89</td>
<td>3.56</td>
<td>7.12</td>
<td>14.24</td>
</tr>
<tr>
<td>7</td>
<td>161</td>
<td>6.44</td>
<td>12.88</td>
<td>25.76</td>
</tr>
<tr>
<td>11</td>
<td>233</td>
<td>9.32</td>
<td>18.64</td>
<td>37.28</td>
</tr>
<tr>
<td>15</td>
<td>305</td>
<td>12.2</td>
<td>24.4</td>
<td>48.8</td>
</tr>
</tbody>
</table>

Note: ACQPS is the acquisition window width. Value of 0 is equal to one ADCCLK period.
In sequential sampling mode, ADC can be configured in cascade mode or dual sequencer mode. In cascade mode, we can schedule 16-ADC conversions sequentially based on an even trigger. The order in which the channels are converted & stored in result register is controlled by ADC Channel selection control register (CHSELSEQ1, CHSELSEQ2, CHSELSEQ3, CHSELSEQ4). For direct mapping of channels to corresponding result register, we need to program the channel selection control register to the values shown below:

CHSELSEQ1 = 0x3210  
CHSELSEQ2 = 0x7654  
CHSELSEQ3 = 0xba98  
CHSELSEQ4 = 0xfedc

<table>
<thead>
<tr>
<th>Channel Selection</th>
<th>Result</th>
</tr>
</thead>
<tbody>
<tr>
<td>A0</td>
<td>CONV00=0</td>
</tr>
<tr>
<td>A1</td>
<td>CONV01=1</td>
</tr>
<tr>
<td>A2</td>
<td>CONV02=2</td>
</tr>
<tr>
<td>A3</td>
<td>CONV03=3</td>
</tr>
<tr>
<td>A4</td>
<td>CONV04=4</td>
</tr>
<tr>
<td>A5</td>
<td>CONV05=5</td>
</tr>
<tr>
<td>A6</td>
<td>CONV06=6</td>
</tr>
<tr>
<td>A7</td>
<td>CONV07=7</td>
</tr>
<tr>
<td>B0</td>
<td>CONV08=8</td>
</tr>
<tr>
<td>B1</td>
<td>CONV09=9</td>
</tr>
<tr>
<td>B2</td>
<td>CONV10=a</td>
</tr>
<tr>
<td>B3</td>
<td>CONV11=b</td>
</tr>
<tr>
<td>B4</td>
<td>CONV12=c</td>
</tr>
<tr>
<td>B5</td>
<td>CONV13=d</td>
</tr>
<tr>
<td>B6</td>
<td>CONV14=e</td>
</tr>
<tr>
<td>B7</td>
<td>CONV15=f</td>
</tr>
</tbody>
</table>
6.2. Simultaneous Sampling mode

In simultaneous sampling mode, the ADC can convert input signals on any pair of channels (A0/B0 to A7/B7). Basically two channels are sampled simultaneously & passed through four stages of ADC pipeline for conversion. Following diagram shows the timing details of 8-pairs of channels (A0/B0 to A7/B7) converted in simultaneous sampling mode based on event trigger:

\[ T = 9*2*T_{adcclk} + 9*(1+ACQPS)*T_{adcclk} \]

Following tables shows the conversion time required to convert all 16-channels in simultaneous sampling mode under different ADC clock frequency & S/H window.

<table>
<thead>
<tr>
<th>ACQPS</th>
<th>Number Of Tadcclk Periods</th>
<th>T in us (ADCCLK=25Mhz)</th>
<th>T in us (ADCCLK=12.5Mhz)</th>
<th>T in us (ADCCLK=6.25Mhz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>27</td>
<td>1.08</td>
<td>2.16</td>
<td>4.32</td>
</tr>
<tr>
<td>3</td>
<td>54</td>
<td>2.16</td>
<td>4.32</td>
<td>8.64</td>
</tr>
<tr>
<td>7</td>
<td>90</td>
<td>3.6</td>
<td>7.2</td>
<td>14.4</td>
</tr>
<tr>
<td>11</td>
<td>126</td>
<td>5.04</td>
<td>10.08</td>
<td>20.16</td>
</tr>
<tr>
<td>15</td>
<td>162</td>
<td>6.48</td>
<td>12.96</td>
<td>25.92</td>
</tr>
</tbody>
</table>
In simultaneous sampling mode, we can schedule 8-pair of simultaneous ADC conversions based on an even trigger (A0/B0, A1/B1, A2/B2, A3/B3, A4/B4, A5/B5, A6/B6, A7/B7). The order in which the channel-pairs are converted & stored in result register is controlled by ADC Channel selection control register (CHSELSEQ1, CHSELSEQ2). To schedule the channels pairs in normal order A0/B0, A1/B1, A2/B2, A3/B3, A4/B4, A5/B5, A6/B6, A7/B7, channel selection register must be programmed to the following values:

\[
\begin{align*}
\text{CHSELSEQ1} &= 0x3210 \\
\text{CHSELSEQ2} &= 0x7654
\end{align*}
\]

<table>
<thead>
<tr>
<th>Channel Selection</th>
<th>RESULT 0</th>
<th>RESULT 1</th>
<th>RESULT 2</th>
<th>RESULT 3</th>
<th>RESULT 4</th>
<th>RESULT 5</th>
<th>RESULT 6</th>
<th>RESULT 7</th>
<th>RESULT 8</th>
<th>RESULT 9</th>
<th>RESULT 10</th>
<th>RESULT 11</th>
<th>RESULT 12</th>
<th>RESULT 13</th>
<th>RESULT 14</th>
<th>RESULT 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>A0</td>
<td>CONV00=0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B0</td>
<td></td>
<td>RESULT 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A1</td>
<td></td>
<td></td>
<td>RESULT 2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B1</td>
<td></td>
<td></td>
<td></td>
<td>RESULT 3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 11</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>A7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 14</td>
<td></td>
</tr>
<tr>
<td>B7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RESULT 15</td>
</tr>
</tbody>
</table>
7. Example Software Calibration Driver

This application note comes with an example C program for simultaneous sampling mode & sequential sampling mode that executes from RAM on the F2812 EzDSP. The example program configures the Event Manager to generate a periodic start of conversion pulse to the ADC. The ADC is configured to process all 16-input channels and then generate an interrupt. In the interrupt service routine, a call is made to an optimized assembly driver which will read the user selected ADC channel references, calculate the calibration gain and offset and calibrate all other channels and store the information in a RAM structure.

The program supports configuring the ADC for simultaneous or sequential conversion modes:

**SEQUENTIAL:**
ADC channels are converted one at a time:
A0 -> A1 -> A2 -> ... B0 -> B1 -> B2 -> ....

**SIMULTANEOUS:**
ADC channels are converted in pairs:
A0,B0 -> A1,B1 -> A2,B2 -> ....

The calibrated and converted channels are stored in a RAM structure which contains the following information:

```c
typedef struct {
    Uint16 *RefHighChAddr;    // Channel Address of RefHigh
    Uint16 *RefLowChAddr;       // Channel Address of RefLow
    Uint16 *Ch0Addr;            // Channel 0 Address
    Uint16 Avg_RefHighActualCount;  // Ideal RefHigh Count (Q4)
    Uint16 Avg_RefLowActualCount;  // Ideal RefLow Count (Q4)
    Uint16 RefHighIdealCount;   // Ideal RefHigh Count (Q0)
    Uint16 RefLowIdealCount;    // Ideal RefLow Count (Q0)
    Uint16 CalGain;             // Calibration Gain   (Q12)
    Uint16 CalOffset;           // Calibration Offset (Q0)
    // Store Calibrated ADC Data (Q0):
    // Simultaneous   Sequential
    // ============  ============
    Uint16 ch0;                 //      A0            A0
    Uint16 ch1;                 //      B0            A1
    Uint16 ch2;                 //      A1            A2
    Uint16 ch3;                 //      B1            A3
    Uint16 ch4;                 //      A2            A4
    Uint16 ch5;                 //      B2            A5
    Uint16 ch6;                 //      A3            A6
    Uint16 ch7;                 //      B3            A7
    Uint16 ch8;                 //      A4            B0
    Uint16 ch9;                 //      B4            B1
    Uint16 ch10;                //      A5            B2
    Uint16 ch11;                //      B5            B3
    Uint16 ch12;                //      A6            B4
    Uint16 ch13;                //      B6            B5
    Uint16 ch14;                //      A7            B6
    Uint16 ch15;                //      B7            B7
    Uint16 StatusExtMux;        // Indicates Status Of External Mux For
    // Current Conversion
}ADC_CALIBRATION_DRIVER_VARS;
```
This program also supports the user toggling a GPIO pin for toggling an external analog mux to expand the usable channels.

To adapt to the user system needs, the user needs to configure assembly time switches and settings contained in the header file:

```
ADCcalibrationDriver.h
```

The user needs to select simultaneous or sequential sampling mode of operation. For example:

```
#define SEQUENTIAL 1
#define SIMULTANEOUS 0
#define ADC_SAMPLING_MODE SIMULTANEOUS
```

And needs to select which ADC channels are connected to reference high and reference low and the ideal count value. For example:

```
A6 = RefHigh = 2.5V (2.5*4095/3.0 = 3413 ideal count)
A7 = RefLow = 1.25V (1.25*4095/3.0 = 1707 ideal count)
```

```
#define REF_HIGH_CH A6
#define REF_LOW_CH A7
#define REF_HIGH_IDEAL_COUNT 3413
#define REF_LOW_IDEAL_COUNT 1707
```

Number of cycles required to execute the calibration driver is:

```
137 cycles or 0.91uS @150MHz (9.7 cycles per user channel)
```

Without calibration, the driver would take approximately 4.7 cycles per user channel to read and store the ADC input. The calibration overhead is therefore approximately an additional 5 cycles per channel.
8. Useful Tips

This is a collection of tips or options that the user can or should consider to improve or guarantee accuracy:

- **Provide Low Resistance Path For ADCLO Pin.** Always make sure that the ADCLO pin on the F2810/12 device is connected directly to analog ground. Any resistance on this pin will further degrade offset and gain errors.

- **Use Bi-Polar Input Conversion Reference As Calibration Input.** When converting bi-polar to uni-polar signals, make sure that the reference voltage used as the “mid-point” of the ADC range is fed as an input calibration channel. This will remove any bi-polar offset error (as discussed earlier in this app-note).

- **Reduce ADCCLK Frequency To Minimum.** At higher sampling frequencies (above 10MHz), the channel-to-channel errors begin to increase. To improve accuracy, users should try to use the lowest frequency that their control system will tolerate. Increasing the sampling window will not have much of an effect on this error at high frequencies.

- **Digital & Analog Grounds Connected At One Point:** To avoid noise created by digital current loops, connect the digital and analog grounds at one point, making sure that any analog or digital current loops do not cross through this point. This is common practice when mixing digital and analog on a single board/device.

The End.