

# **AN2834 Application note**

## How to optimize the ADC accuracy in the STM32 MCUs

## **Introduction**

STM32 MCUs embed advanced 12-bit to 16-bit ADCs depending on the device. A selfcalibration feature is provided to enhance ADC accuracy versus environmental condition changes.

In applications involving analog-to-digital conversion, ADC accuracy has an impact on the overall system quality and efficiency. To improve this accuracy, the errors associated with the ADC and the parameters affecting them must be understood.

ADC accuracy does not only depend on ADC performance and features, but also on the overall application design around the ADC.

This application note aim is to help understand ADC errors and explain how to enhance ADC accuracy. It is divided into three main parts:

- A simplified description of ADC internal structure to help understand ADC operation and related ADC parameters.
- Explanations of the different types and sources of ADC errors, related to the ADC design and to external ADC parameters, such as the external hardware design.
- Recommendations on how to minimize these errors, focusing on hardware and software methods.

# **Contents**









# **List of tables**





# **List of figures**





## <span id="page-5-0"></span>**1 General information**

This application note applies to STM32 Arm*®*(a)-based microcontrollers.

# arm

# <span id="page-5-1"></span>**2 ADC internal principle**

## <span id="page-5-2"></span>**2.1 SAR ADC internal structure**

The ADC embedded in STM32 microcontrollers uses the *SAR (successive approximation register)* principle, by which the conversion is performed in several steps. The number of conversion steps is equal to the number of bits in the ADC converter. Each step is driven by the ADC clock. Each ADC clock produces one bit from result to output. The ADC internal design is based on the switched-capacitor technique.

The following figures (*[Figure](#page-5-3) 1* to *[Figure](#page-8-3) 6*) explain the principle of ADC operation. The example given below shows only the first steps of approximation but the process continues until the LSB is reached.



<span id="page-5-3"></span>**Figure 1. Basic schematic of SAR switched-capacitor ADC (example of 10-bit ADC)**

1. Basic ADC schematic with digital output.

a. Arm is a registered trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere.





<span id="page-6-0"></span>

1. Sample state: capacitors are charging to  $V_{IN}$  voltage. Sa switched to  $V_{IN}$ , Sb switch closed during sampling time.

<span id="page-6-1"></span>

1. Hold state: the input is disconnected. Capacitors hold the input voltage. Sb switch is open, then S1-S11 switched to ground and Sa switched to  $V_{REF}$ .



<span id="page-7-0"></span>

Figure 4. Step 1: Compare with V<sub>REF</sub>/2

1. First approximation step. S1 switched to  $V_{REF}$ .

<span id="page-7-1"></span>

## Figure 5. Step 2: If MSB = 0, then compare with  $\frac{1}{4}V_{REF}$

1. Compare with  $\frac{1}{4}V_{REF}$ ; if MSB = 0. S1 switched back to the ground. S2 switched to  $V_{REF}$ .



<span id="page-8-3"></span>

Figure 6. Step 2: If MSB = 1, then compare with  $\frac{3}{4}V_{REF}$ 

1. Compare with  $\frac{3}{4}V_{REF}$ ; if MSB = 1. S1 remained switched to ground. S2 switched to  $V_{REF}$ .

## <span id="page-8-0"></span>**3 ADC errors**

This section lists the main errors that have an effect on A/D conversion accuracy. These types of errors occur in all A/D converters and conversion quality depends on their elimination. These error values are specified in the ADC characteristics section of STM32 microcontroller datasheets.

Different accuracy error types are specified for the STM32 ADC. For easy reference, accuracy errors are expressed as multiples of one1 LSB. The resolution in terms of voltage depends on the reference voltage. The error in terms of voltage is calculated by multiplying the number of LSBs by the voltage corresponding to 1 LSB:

1 LSB =  $V_{RFF+}/2^N$  or  $V_{DDA}/2^N$  for an N-bit ADC

## <span id="page-8-1"></span>**3.1 Errors due to the ADC itself**

## <span id="page-8-2"></span>**3.1.1 Offset error**

The offset error is the deviation between the first actual transition and the first ideal transition. The first transition occurs when the digital ADC output changes from 0 to 1. Ideally, when the analog input ranges between 0.5 LSB and 1.5 LSB, the digital output must be 1. Still ideally, the first transition occurs at 0.5 LSB. The offset error is denoted by  $E_{\Omega}$ . The offset error can easily be calibrated by the application firmware.



#### **Example**

For the STM32 ADC, the smallest detectable incremental change in voltage is expressed in terms of LSBs:

1 LSB =  $V_{RFF+}/4096$  (on some packages,  $V_{RFF+}$  =  $V_{DDA}$ ).

If  $V_{REF+}$  = 3.3 V, the input of 402.8 µV (0.5 LSB = 0.5 × 805.6 µV) must ideally lead to the generation of a digital output of 1. In practice, however, the ADC may still provide a reading of 0. If a digital output of 1 is obtained from an analog input of 550 µV, then:

Offset error = Actual transition – Ideal transition

 $E_{\Omega}$  = 550 µV – 402.8 µV = 141.2 µV

 $E_{\Omega}$  = 141.2 µV / 805.6 µV = 0.17 LSB

When an analog input voltage greater than 0.5 LSB generates the first transition, the offset error is positive (refer to *[Figure](#page-9-0) 7* for an example of positive offset error).

<span id="page-9-0"></span>

1. The error offset,  $E_O$ , is shown in magenta.

When an analog input voltage of less than 0.5 LSB generates the first transition, the offset error is negative (refer to *[Figure](#page-9-1) 8* for an example of negative offset error).

If the analog input voltage ( $V_{AlN}$ ) is equal to  $V_{SSA}$  and the ADC generates a nonzero digital output, the offset error is negative. This means that a negative voltage generates the first transition.

<span id="page-9-1"></span>

**Figure 8. Negative offset error representation**

1. The error offset,  $E_O$ , is shown in magenta.

1[0/53](#page-52-0) AN2834 Rev 10



### <span id="page-10-0"></span>**3.1.2 Gain error**

The gain error is the deviation between the last actual transition and the last ideal transition. It is denoted by  $E_G$ .

The last actual transition is the transition from 0xFFE to 0xFFF. Ideally, there must be a transition from 0xFFE to 0xFFF when the analog input is equal to  $V_{RFF+}$  – 0.5 LSB. So, for  $V_{\text{RFE+}}$ = 3.3 V, the last ideal transition must occur at 3.299597 V.

If the ADC provides the 0xFFF reading for  $V_{AlN} < V_{REF+} - 0.5$  LSB, then a negative gain error is obtained.

#### **Example**

The gain error is obtained by the formula below:

 $E_G$  = Last actual transition – ideal transition

If  $V_{REF+}$  = 3.3 V and  $V_{AIN}$  = 3.298435 V generate a transition from 0xFFE to 0xFFF then:

 $E_G$  = 3.298435 V – 3.299597 V  $E_G = -1162 \mu V$  $E_G = (-1162 \mu V / 805.6 V) LSB = -1.44 LSB$ 

If a full-scale reading (0xFFF) is not obtained for  $V_{AlN}$  equal to  $V_{REF+}$ , the gain error is positive. This means that a voltage greater than V<sub>REF+</sub> causes the last transition. *[Figure](#page-10-1)* 9 shows a positive gain error while *[Figure](#page-11-1) 10* shows a negative gain error.

<span id="page-10-1"></span>

#### **Figure 9. Positive gain error representation**

1. The gain error,  $E_G$ , is shown in magenta.



<span id="page-11-1"></span>

**Figure 10. Negative gain error representation**

1. The gain error,  $E_G$ , is shown in magenta.

## <span id="page-11-0"></span>**3.1.3 Differential linearity error**

The differential linearity error (DLE) is the maximum deviation between the actual and ideal steps. Here 'ideal' does not refer to the ideal transfer curve but to the ADC resolution. The DLE is denoted by  $E_D$ . It is represented in *[Figure](#page-11-2) 11*.

 $E_D$  = Actual step width – 1 LSB

Ideally, an analog input voltage change of 1 LSB must cause a change in the digital code. If an analog input voltage greater than 1 LSB is required for a change in digital code, a differential linearity error is observed. The DLE therefore corresponds to the maximum additional voltage that is required to change from one digital code to the next.

The DLE is also known as the differential nonlinearity (DNL) error.

#### **Example**

A given digital output must correspond to an analog input range. Ideally, the step width must be 1 LSB. Let us assume that the digital output is the same over an analog input voltage range of 1.9998 V to 2.0014 V. The step width is:

2.0014 V – 1.9998 V = 1.6 mV.

 $E_D$  is thus the voltage difference between the higher (2.0014 V) and the lower (1.9998 V) analog voltages minus the voltage corresponding to 1 LSB.

<span id="page-11-2"></span>

#### **Figure 11. Differential linearity error representation**

1. The differential linearity error,  $E_D$ , is shown in magenta.



If  $V_{RFF+}$  = 3.3 V, an analog input of 1.9998 V (0x9B2) can provide results varying between 0x9B1 and 0x9B3. Similarly, for an input of 2.0014 V (0x9B4), the results may vary between 0x9B3 and 0x9B5.

As a result, the total voltage variation corresponding to the 0x9B3 step is:

 $0x9B4 - 0x9B2$ , that is, 2.0014 V - 1.9998 V = 1.6 mV (1660 µV)

 $E_D$  = 1660 µV – 805.6 µV  $E_D = 854.4 \text{ mV}$  $E_D$  = (854.4 µV/805.6 µV) LSB  $E_D$  = 1.06 LSB

## <span id="page-12-0"></span>**3.1.4 Integral linearity error**

The integral linearity error is the maximum deviation between any actual transition and the endpoint correlation line. The ILE is denoted by  $E_1$ . It is represented in *[Figure](#page-12-1)* 12.

The endpoint correlation line can be defined as the line on the A/D transfer curve that connects the first actual transition with the last actual transition.  $E_1$  is the deviation from this line for each transition. The endpoint correlation line thus corresponds to the actual transfer curve and has no relation to the ideal transfer curve.

The ILE is also known as the integral nonlinearity error (INL). The ILE is the integral of the DLE over the whole range.

<span id="page-12-1"></span>

#### **Figure 12. Integral linearity error representation**

1. The integral linearity error,  $E_L$ , is shown in magenta.

#### **Example**

If the first transition from 0 to 1 occurs at 550 µV and the last transition (0xFFE to 0xFFF) occurs at 3.298435 V (gain error), then the line on the transfer curve that connects the actual digital codes 0x1 and 0xFFF is the endpoint correlation line.



## <span id="page-13-0"></span>**3.1.5 Total unadjusted error**

The total unadjusted error (TUE) is the maximum deviation between the actual and the ideal transfer curves. This parameter specifies the total errors that may occur, thus causing the maximum deviation between the ideal digital output and the actual digital output. TUE is the maximum deviation recorded between the ideal expected value and the actual value obtained from the ADC for any input voltage.

The TUE is denoted by  $E_T$ . It is represented in *[Figure](#page-13-3)* 13.

The TUE is not the sum of  $E_O$ ,  $E_O$ ,  $E_I$ ,  $E_D$ . The offset error affects the digital result at lower voltages whereas the gain error affects the digital output for higher voltages.

#### **Example**

If  $V_{REF+}$  = 3.3 V and  $V_{AIN}$  = 2 V, the ideal result is 0x9B2.

TUE = absolute (actual value – ideal case value) =  $0x9B4 - 0x9B2 = 0x2 = 2$  LSB

<span id="page-13-3"></span>



1. The total unadjusted error,  $E_T$ , is shown in magenta.

## <span id="page-13-1"></span>**3.2 Errors due to the ADC environment**

## <span id="page-13-2"></span>**3.2.1 Reference voltage noise**

As the ADC output is the ratio between the analog signal voltage and the reference voltage, any noise on the analog reference causes a change in the converted digital value.  $V_{\text{DDA}}$ analog power supply is used on some packages as the reference voltage ( $V_{REF+}$ ), so the quality of  $V_{\text{DDA}}$  power supply has an influence on ADC error.

For example, with an analog reference of 3.3 V ( $V_{REF+} = V_{DDA}$ ) and a 1 V signal input, the converted result is:

 $(1/3.3) \times 4096 = 0x4D9$ 

However, with a 40 mV peak-to-peak ripple in the analog reference, the converted value becomes:

 $(1/3.34)$  × 4096 = 0x4CA (with  $V_{REF+}$  at its peak).  $Error = 0x4D9 - 0x4CA = 15LSB$ 



The SMPS (switch-mode power supply) usually embeds internal fast-switching power transistors. This introduces high-frequency noise in the output. The switching noise is in the range of 15 kHz to 1 MHz.

## <span id="page-14-0"></span>**3.2.2 Reference voltage / power supply regulation**

Power supply regulation is very important for ADC accuracy since the conversion result is the ratio of the analog input voltage to the  $V_{REF+}$  value.

If the power supply output decreases when connected to  $V_{DDA}$  or  $V_{REF+}$  due to the loads on these inputs and to its output impedance, an error is introduced in the conversion result.

Digital code =  $\frac{V_{AIN}(2^N)}{M}$ , where N is the resolution of the ADC (in our case N = 12 and  $=\frac{V_{RIR} - V_{REF+}}{V_{REF+}}$ 

digital code range =  $[0 \text{ to } (2^N-1)]$ .

If the reference voltage changes, the digital result changes too.

For example:

If the supply used is a reference voltage of 3.3 V and  $V_{AIN} = 1$  V, the digital output is:

Digital<sub>output</sub> = 
$$
\frac{1 \times (2^{12})}{3.3}
$$
 = 0x4D9

If the voltage supply provides a voltage equal to 3.292 V (after its output connection to  $V_{RFF+}$ ), then:

Digital<sub>output</sub> = 
$$
\frac{1 \times (2^{12})}{3.292}
$$
 = 0x4DC

The error introduced by the voltage drop is: 0x4DC – 0x4D9 = 3 LSB.

## <span id="page-14-1"></span>**3.2.3 Reference voltage decoupling and impedance**

The reference voltage source must have a low output impedance to provide a nominal voltage under various load conditions. Both resistive and inductive parts of the output impedance are important. During the ADC conversion, the reference voltage is connected to the switched capacitor network (see *[Figure 4.](#page-7-0)* and *[Figure 5.](#page-7-1)*). The capacitors of this network are charged/discharged from/to a reference voltage in a very short time during successive approximations (one approximation cycle corresponding to one ADC clock period). The reference voltage must provide high current peaks to capacitors. Voltages on capacitors must be stable at the end of each approximation cycle (zero current from the reference voltage). Therefore, the reference voltage must have a very low output impedance including low inductance (to provide high current peaks in a very short time). Parasitic inductance can prevent the charging process from being fully finished at the end of the approximation cycle or oscillations can appear in the LC circuit (parasitic inductance together with capacitor



AN2834 Rev 10 15/[53](#page-52-0)

network). In this case, the result of the approximation cycle is inaccurate. Correct decoupling capacitors on the reference voltage located very close to pins provide a low source impedance.

### <span id="page-15-0"></span>**3.2.4 External reference voltage parameters**

In case of using an external source for reference voltage (on  $V_{REF+}$  pin), there are important parameters of this external reference source to consider. Three reference voltage specifications must be considered: temperature drift, voltage noise, long-term stability.

## <span id="page-15-1"></span>**3.2.5 Analog input signal noise**

Small but high-frequency signal variation can result in significant conversion errors during sampling time. This noise is generated by electrical devices, such as motors, engine ignition, and power lines. It affects the source signal (such as sensors) by adding an unwanted signal. As a consequence, the ADC conversion results are not accurate.

## <span id="page-15-2"></span>**3.2.6 ADC dynamic range bad match for maximum input signal amplitude**

To obtain the maximum ADC conversion precision, it is very important that the ADC dynamic range matches the maximum amplitude of the signal to be converted. Let us assume that the signal to be converted varies between 0 V and 2.5 V and that  $V_{BEF+}$  is equal to 3.3 V. The maximum signal value converted by the ADC is 3103 (2.5 V) as shown in *[Figure](#page-15-4) 14*. In this case, there are 992 unused transitions (4095 – 3103 = 992). This implies a loss in the converted signal accuracy.

See *Section [4.2.5: Matching the ADC dynamic range to the maximum signal amplitude on](#page-23-0)  [page](#page-23-0) 24* for details on how to make the ADC dynamic range match the maximum input signal amplitude.

<span id="page-15-4"></span>

### Figure 14. Input signal amplitude vs. ADC dynamic range (V<sub>REF+</sub> = 3.3 V)

### <span id="page-15-3"></span>**3.2.7 Effect of the analog signal source resistance**

The impedance of the analog signal source, or series resistance  $(R_{A|N})$ , between the source and pin, causes a voltage drop across it because of the current flowing into the pin. The charging of the internal sampling capacitor  $(C_{ADC})$  is controlled by switches with a resistance  $R_{ADC}$ .

With the addition of source resistance (with  $R_{ADC}$ ), the time required to fully charge the hold capacitor increases. *[Figure](#page-16-1) 15* shows the analog signal source resistance effect.



The effective charging of  $C_{ADC}$  is governed by  $R_{ADC}$  +  $R_{AIN}$ , so the charging time constant becomes  $t_c = (R_{ADC}+R_{AIN}) \times C_{ADC}$ . If the sampling time is less than the time required to fully charge the C<sub>ADC</sub> through R<sub>ADC</sub> + R<sub>AIN</sub> ( $t_s$  <  $t_c$ ), the digital value converted by the ADC is less than the actual value.

<span id="page-16-1"></span>



1.  $t_c$  is the time taken by the C<sub>ADC</sub> capacitor to fully charge:  $V_c = V_{AlN}$  (with max.1/2 LSB error)<br>  $V_c$ : capacitor (C<sub>ADC</sub>) voltage<br>  $t_c = (R_{ADC} + R_{AlN}) \times C_{ADC}$ 

## <span id="page-16-0"></span>**3.2.8 Effect of source capacitance and parasitic capacitance of the PCB**

When converting analog signals, it is necessary to account for the capacitance at the source and the parasitic capacitance seen on the analog input pin (refer to *[Figure](#page-16-2) 16*). The source resistance and capacitance from an RC network. In addition, the ADC conversion results may not be accurate, except if the external capacitor  $(C_{AIN} + C_p)$  is fully charged to the level of the input voltage. The greater value of  $(C_{AIN} + C_p)$ , the more limited the source frequency.

The external capacitance at the source and the parasitic capacitance are denoted by  $C_{AIN}$ and  $C_p$ , respectively.

<span id="page-16-2"></span>





## <span id="page-17-0"></span>**3.2.9 Injection current effect**

A negative injection current on any analog pin (or a closely positioned digital input pin) may introduce leakage current into the ADC input. The worst case is the adjacent analog channel. A negative injection current is introduced when  $V_{AIN} < V_{SS}$ , causing the current to flow out from the I/O pin. This is illustrated in *[Figure](#page-17-3) 17*.

<span id="page-17-3"></span>

**Figure 17. Effect of injection current**

## <span id="page-17-1"></span>**3.2.10 Temperature influence**

The temperature has a major influence on ADC accuracy. Mainly it leads to two major errors: offset error drift and gain error drift. Those errors can be compensated in the microcontroller firmware (refer to *[Section](#page-34-0) 4.2.9* for the temperature-compensation methods).

## <span id="page-17-2"></span>**3.2.11 I/O pin crosstalk**

Switching the I/Os may induce some noise in the analog input of the ADC due to capacitive coupling between I/Os. Crosstalk may be introduced by PCB tracks that run close to each other or that cross each other.

Internally switching digital signals and I/Os introduces high-frequency noise. Switching highsink I/Os may induce some voltage dips in the power supply caused by current surges. A digital track that crosses an analog input track on the PCB may affect the analog signal (see *[Figure](#page-18-1) 18*).



<span id="page-18-1"></span>

1. Case 1: Digital and analog signal tracks that pass close to each other.

2. Case 2: Digital and analog signal tracks that cross each other on a different PCB side.

## <span id="page-18-0"></span>**3.2.12 EMI-induced noise**

Electromagnetic emissions from neighboring circuits may introduce high-frequency noise in an analog signal because the PCB tracks may act like an antenna (See *[Figure 19.](#page-18-2)*).

<span id="page-18-2"></span>

## <span id="page-19-0"></span>**4 How to optimize the ADC accuracy**

## <span id="page-19-1"></span>**4.1 Reduce the effects of the ADC-related ADC errors**

The TUE is not the sum of all the  $E_O$ ,  $E_G$ ,  $E_L$ ,  $E_D$  errors. It is the maximum deviation that can occur between the ideal and actual digital values. It can result from one or more errors occurring simultaneously.

As the ILE is the integral of the DLE, it can be considered as the indicator of the maximum error. Do not add the DLE and ILE together to calculate the maximum error that may occur at any digital step.

The maximum error values specified in the device datasheet are the worst error values measured in a laboratory test environment over the given voltage and temperature range (refer to the device datasheet).

The ILE and DLE are dependent on the ADC design. It is difficult to calibrate them. They can be calibrated by the measured ADC curve stored in the microcontroller memory but this needs calibration of each individual device in the final application.

Offset and gain errors can be easily compensated using the STM32 ADC self-calibration feature or by microcontroller firmware.

## <span id="page-19-2"></span>**4.2 Minimize the ADC errors related to the ADC external environment**

## <span id="page-19-3"></span>**4.2.1 Reference voltage / power supply noise minimization**

### **On the power supply side**

Linear regulators have a better output in terms of noise. The mains must be stepped down, rectified, and filtered, then fed to linear regulators. It is highly recommended to connect the filter capacitors to the rectifier output. Refer to the datasheet of the used linear regulator.

When using a switching power supply, it is recommended to have a linear regulator to supply the analog stage.

It is recommended to connect capacitors with good high-frequency characteristics between the power and ground lines. That is, a 0.1 µF and a 1 to 10 µF capacitor must be placed close to the power source.

The capacitors allow the AC signals to pass through them. The small-value capacitors filter high-frequency noise and the high-value capacitors filter low-frequency noise. Ceramic capacitors are generally available in small values (1  $pF$  to 0.1  $\mu$ F) and with small voltage ratings (16 V to 50 V). It is recommended to place them close to the main supply ( $V_{DD}$  and  $V_{SS}$ ) and analog supply ( $V_{DDA}$  and  $V_{SSA}$ ) pins. They filter the noise induced in the PCB tracks. Small capacitors can react fast to current surges and discharge quickly for fastcurrent requirements.

Tantalum capacitors can also be used along with ceramic capacitors. To filter low-frequency noise, high-value capacitors (10  $\mu$ F to 100  $\mu$ F), which are generally electrolytic, can be used. It is recommended to put them near the power source.



To filter high-frequency noise, a ferrite inductance in series with the power supply can be used. This solution leads to very low (negligible) DC loss unless the current is high because the series resistance of the wire is very low. At high frequencies, however, the impedance is high.

The inductance must be small enough not to limit high current peak requirements from the supply pins. The inductance together with the decoupling capacitor is an LC circuit, which can start to oscillate if there is a fast voltage drop on the decoupling capacitor, caused by a change of consumption (on  $\mathsf{V}_{\mathsf{DDA}}, \mathsf{V}_{\mathsf{DD}}, \mathsf{V}_{\mathsf{REF+}}$ ). The oscillations can take more time and influence the ADC measurement (oscillations on  $\rm{V_{REF+}}$  during conversion). To suppress these oscillations, it is recommended to use small inductances and with ferrite cores, which have losses at high frequencies (resistive character of the impedance).

#### **On the STM32 microcontroller side**

In most STM32 microcontrollers, the  $V_{DD}$  and  $V_{SS}$  pins are placed close to each other. So are the  $V_{REF+}$  and  $V_{SSA}$  pins. A capacitor can therefore be connected very close to the microcontroller with very short leads. For multiple  $V_{DD}$  and  $V_{SS}$  pins, use separate decoupling capacitors.

The  $V_{DDA}$  pin must be connected to two external decoupling capacitors (10 nF Ceramic + 1 µF Tantalum or Ceramic). Refer to *[Figure](#page-20-0) 20* and *[Figure](#page-21-2) 21* for decoupling examples.

For STM32 microcontrollers delivered in 100/144-pin packages, it is possible to improve the accuracy on low-voltage inputs by connecting a separate external ADC reference voltage input on  $V_{REF+}$  (refer to *[Section](#page-23-0) 4.2.5*). The voltage on  $V_{REF+}$  may range from 2.4 V to  $V_{DDA}$ . If a separate, external reference voltage is applied on  $V_{REF+}$ , two 10 nF and 1 µF capacitors must be connected on this pin. In all cases,  $V_{RFF+}$  must be kept between 2.4 V and  $V_{DDA}$ .



<span id="page-20-0"></span>**Figure 20. Power supply and reference decoupling for 100- and 144-pin packages**



<span id="page-21-2"></span>

#### **Figure 21. Power supply decoupling for 36-, 48- and 64-pin packages**

## <span id="page-21-0"></span>**4.2.2 Reference voltage / power supply regulation**

The power supply must have good line and load regulation since the ADC uses  $V_{RFF+}$  or  $V<sub>DDA</sub>$  as the analog reference and the digital value is the ratio of the analog input signal to this voltage reference.  $V_{RFF+}$  must thus remain stable at different loads.

Whenever the load is increased by switching on a part of the circuit, the increase in current must not cause the voltage to decrease. If the voltage remains stable over a wide current range, the power supply has good load regulation.

For example, for the LD1086D2M33 voltage regulator, the line regulation is 0.035% typical when V<sub>IN</sub> varies from 2.8 V to 16.5 V (when  $I_{load} = 10$  mA), and the load regulation is 0.2% when  $I_{load}$  varies from 0 to 1.5 A (please refer to the LD1086 series datasheet for details).

The lower the line regulation value, the better the regulation. Similarly, the lower the load regulation value, the better the regulation and the stability of the voltage output.

It is also possible to use a reference voltage for  $V_{REF+}$ , for instance the TL1431A, which is a voltage reference diode of 2.5 V (refer to TL1431A datasheet for more details).

The reference voltage source design must provide a low output impedance (static and dynamic). The parasitic serial resistance and inductance must be minimized. Correct decoupling capacitors on the reference voltage located very close to pins provide a low reference voltage source impedance.

## <span id="page-21-1"></span>**4.2.3 Analog-input signal noise elimination**

### **Averaging method**

Averaging is a simple technique that involves sampling an analog input several times and using software to calculate the average of the results.This technique is helpful to eliminate the effect of noise on the analog input in the case of an analog voltage that does not change often.

The average has to be made on several readings that all correspond to the same analog input voltage. Make sure that the analog input remains at the same voltage during the time period when the conversions are done. Otherwise, digital values corresponding to different analog inputs may be added up, introducing errors.

In the STM32 microcontrollers with the ADC oversampling feature, the ADC hardware oversampling feature can be used for averaging. This feature simply performs the sum of a given number of ADC raw samples into one final sample. This final sample can then be right shifted to reduce the bit width caused by multiple ADC samples accumulation. All these operations (accumulation and right-bit shifting) are performed by hardware. The ADC



hardware oversampling feature can be configured to process up to 1024 input samples (depending on devices).

#### **Adding an external filter**

Adding an external RC filter eliminates the high frequency. An expensive filter is not needed to deal with a signal that has frequency components above the frequency range of interest. In this case, a relatively simple low-pass filter with a cutoff frequency  $f_C$  just above the frequency range of interest suffices to limit noise and aliasing. A sampling rate consistent with the highest frequency of interest suffices, typically two to five times  $f_C$ .

*Note: The R and C that form the external filter must have values that match the conditions described in [Section](#page-22-0) 4.2.4 and [Section](#page-33-1) 4.2.8.* 

## <span id="page-22-0"></span>**4.2.4 Adding white noise or triangular sweep to improve resolution**

This method combines hardware and software techniques to improve precision. From a software point of view, this method uses averaging (oversampling) and from a hardware point of view, it uses signal modification/spreading/dithering.

Averaging can be used in cases where the input signal is noisy (some signal change is necessary to be able to calculate an average) and the requirement is to obtain the mean value of a signal. A problem appears when the input signal is a very stable voltage without noise. In this case, when the input signal is measured, each data sample is the same. This is because the input signal level is somewhere between two ADC word levels (for instance, between 0x14A and 0x14B). Therefore, it is not possible to determine the input voltage level more precisely (for example, if the level is near to 0x14A or near to 0x14B level).

The solution is to add noise or some signal change (with uniform signal distribution, for example, triangular sweep) to the input signal, which pushes its level across 1-bit ADC level (so that the signal level changes below 0x14A and above 0x14B level). This causes the ADC results to vary. Applying software averaging to the different ADC results, produces the mean value of the original input signal. Some STM32 microcontrollers support hardware oversampling, which can be used instead of software oversampling.

As an example, this method can be implemented by using a triangular generator with RC coupling to the input signal (white noise generation is more complicated). Care must be taken not to modify the mean value of the original input signal (so, capacitive coupling must be used).

A very simple implementation of the quasi-triangular source, which is generated directly by the STM32 microcontroller is on *[Figure](#page-23-1) 22*.



<span id="page-23-1"></span>

#### **Figure 22. Simple quasi-triangular source using a microcontroller output**

## <span id="page-23-0"></span>**4.2.5 Matching the ADC dynamic range to the maximum signal amplitude**

This method improves accuracy by a proper selection of the reference voltage or by using a preamplifier stage to obtain the maximum possible resolution using the full ADC output range.

## **Selecting a reference voltage (method for devices delivered in packages with**  a dedicated V<sub>REF+</sub> pin)

The reference voltage is selected in the expected range of the signal to be measured. If the measured signal has an offset, then the reference voltage must also have a similar offset. If the measured signal has a defined maximum amplitude, then the reference voltage must also have a similar maximum value. By matching this reference voltage to the measurement signal range, we obtain the maximum possible resolution using the full ADC output range.

In STM32 microcontrollers delivered in packages with a dedicated  $V_{REF+}$  pin, the ADC reference voltage is connected to the external  $V_{REF+}$  and  $V_{REF-}$  pins that must be tied to ground. This makes it possible to match the reference voltage and the measured signal range.

For example, if the measured signal varies between 0 V and 2.5 V, it is recommended to choose a  $V_{RFF+}$  of 2.5 V, possibly using a reference voltage like TL1431A (see TL1431A datasheet for more details). *[Figure](#page-24-1) 23* illustrates these conditions.

*Note:* The voltage on  $V_{RFF+}$  may range between 2.4 V and  $V_{DDA}$ .



<span id="page-24-1"></span>

#### **Figure 23. Selecting the reference voltage**

### **Using a preamplifier**

If the measured signal is too small (in comparison with the ADC range), then an external preamplifier can be useful. This method can be implemented whatever the STM32 package, and more specifically in packages that do not have a  $V_{RFF+}$  input.

For example, if the measured signal varies between 0 V to 1 V and  $V_{DDA}$  is set to 3 V, the signal can be amplified so that its peak-to-peak amplitude is similar to the  $V_{DDA}$  value. The gain is then equal to 3 (see *[Figure](#page-24-2) 24* for an example).

This amplifier can adapt the input signal range to the ADC range. It can also insert offsets between the input signal and the ADC input. When designing the preamplifier, care must be taken not to generate additional errors (such as additional offset, amplifier gain stability or linearity, frequency response).

<span id="page-24-2"></span>

#### **Figure 24. Preamplification**

## <span id="page-24-0"></span>**4.2.6 SAR ADC sampling time prerequisites**

### **SAR ADC sample conversion process**

The SAR ADC sample conversion process consists in two successive operations: sampling and bit conversion. When these operations are completed, the sample conversion result is available in the ADC data register (ADC\_DR). When the ADC conversion has started, the new converted data is available after a sample conversion time of  $T<sub>CONV</sub>$ . When continuous acquisition is performed, a new data is available every  $T_{CONV}$  and it can be converted into



the ADC sampling rate. The number of samples obtained in one second can be computed using the following formula:

ADC sampling rate =  $1/$  (sample conversion duration) =  $1/$  T<sub>CONV</sub>

#### **Figure 25. SAR ADC sample conversion process**

<span id="page-25-0"></span>

The following paragraph describes the two successive operations required for sample conversion:

1. Sampling

This operation samples the analog input signal by charging the internal ADC sampling capacitor  $(C_{ADC})$ .

The duration of this operation is  $T_{SMPL}$ . It depends on the SMP parameter that is configured in the ADC configuration register to select the sampling time duration.

2. Bit conversion

This operation converts the analog value stored in the  $C_{ADC}$  sampling capacitor to a digital value.

The duration of this operation is  $T<sub>SAR</sub>$ . It depends on the RES parameter that is configured in the ADC configuration register to select the ADC bit resolution.

ADC sample conversion time  $(T_{CONV}) =$  Sampling time  $(T_{SMPL})$  + Bit conversion time  $(T_{SAR})$ 

ADC sample rate =  $1/ T_{CONV} = 1/ (T_{SMPI} + T_{SAR})$ 

Both  $T_{SMPL}$  and  $T_{SAR}$  durations are relative to multiple of ADC clock cycles:

- $T_{SMPI}$  duration: This duration depends on the SMP parameter (ADC sampling duration). As an example, SMP values for STM32L5 series can be 2.5, 6.5, 12.5, 24.5, 47.5, 92.5, 247.5 or 640.5 ADC clock cycles.
- T<sub>SAR</sub> duration:

This duration depends on the RES parameter (ADC bit resolution). As an example, RES values for STM32L5 series can be 6.5, 8.5, 10.5 and 12.5 ADC clock cycles for 6, 8, 10 and 12-bit resolution.

The ADC sampling rate or sample conversion time  $(T_{CONV})$  can be calculated using the following formula:

 ${\sf T}_{\sf CONV}$  =  ${\sf T}_{\sf SMPL}$  +  ${\sf T}_{\sf SAR}$  = 2.5  $\times$   ${\sf T}_{\sf ADC\_CLK}$  + 12.5  $\times$   ${\sf T}_{\sf ADC\_CLK}$  = 15  $\times$   ${\sf T}_{\sf ADC\_CLK}$  $15 \times 1$  F ADC\_CLK  $= 15 \times 20$  ns  $= 300$  ns  $T_{cMD}$  +  $T_{cAD}$  = 2.5  $\times$   $T_{ADC}$   $C_K$  + 12.5  $\times$   $T_{ADC}$   $C_K$  = =  $15 \times 1$ /  $F_{ADC}$   $C_{LK}$  =  $15 \times 20$  ns =



ADC sample rate =  $1/ T_{\text{CONV}} = 3.33^6$  samples per second or 3.33 MSPS

where

 $F_{ADC}$   $CLK = 50$  MHz  $T_{SMPI}$  = 2.5 clock cycles  $T<sub>SAD</sub>$  = 12.5 (ADC 12-bit resolution):

## **SAR ADC sampling T<sub>SMPL</sub> and T<sub>SAR</sub> constraints**

 $T<sub>SMPI</sub>$  and  $T<sub>SAR</sub>$  durations must be selected according to the application scope and environment.  $T<sub>SAR</sub>$  is easier to choose since it depends only on the selected ADC bit resolution (6, 8, 10 or 12 bits).  $T_{SMPL}$  is more complex and depends on various parameters:

- $T<sub>SMPI</sub>$  minimum duration depends on the external electrical components of the input path (*[Section 3.2.7: Effect of the analog signal source resistance](#page-15-3)* and *[Section 3.2.8:](#page-16-0)  [Effect of source capacitance and parasitic capacitance of the PCB](#page-16-0)*):
	- $R_{\text{AIN}}$ : analog source output impedance
	- $C_{PCB}$  or  $C_{AIN}$ : PCB parasitic capacitor or analog input decoupling/filtering capacitor
	- $T_{SMPI}$  depends on the internal STM32 SAR circuitry ( $R_{PAR}$ ,  $C_{PAR}$  and  $C_{ADC}$ ):
		- SAR ADC channel type: fast, slow, direct (refer to the device datasheet)
		- Internal circuitry parameters vary according to the package dimensions, manufacturing process, temperature, and supply voltage levels.
- $T<sub>SMPI</sub>$  also varies according to application constraints and functionalities:
	- Maximum conversion error: ±1 LSB or higher
	- ADC resolution (expressed in bits)
	- Number of ADCs running in parallel

#### **Figure 26. Simplified external/internal SAR ADC sampling diagram**

<span id="page-26-0"></span>

Based on the above constraints, the minimum  $T_{SMPL}$  required to achieve the maximum output sampling rate can then be estimated.

The device datasheet provides a few  $T_{SMPL}$  values to obtain a maximum accuracy of  $\pm$  1/2 LSB for each channel type, different  $R_{AlN}$  values, a given CAIN/CPCB capacitor, and in the



worst conditions of package dimensions, temperature, manufacturing process and supply voltages.

*[Figure](#page-28-1)* 27 and *Figure* 28 show the impact of the desired accuracy (from  $\pm$  0.5 to  $\pm$  3 LSB) and ADC resolution (expressed in LSB) on the input signal to reach the voltage accuracy. When the resolution is low and the error accuracy is high, the required signal sampling time is short, whereas when the resolution is high and the error accuracy is low, the required signal sampling time is long.

*[Figure](#page-27-0) 27* shows that the sampling duration increases with the ADC resolution. It also shows the voltage variation on the STM32 ADC analog input pin. The first ADC conversion starts at 0 ns. For negative timings, the curve shows the input voltage state before the first ADC conversion.

<span id="page-27-0"></span>

**Figure 27. Example of SAR ADC input sampling time vs ADC resolution**

1. The above results are obtained in the following conditions: V<sub>REF+</sub> = 2 V<br>R<sub>AIN =</sub> 1 kΩ C<sub>AIN</sub>/C<sub>PCB</sub> = 2 nF<br>Typical conditions of voltage, temperature, process, package, and number of ADCs running.



*[Figure](#page-28-1) 28* shows that the sampling duration has to be increased to achieve a higher accuracy: a 23.8 ns sampling duration is required to obtain a 12-bit resolution and ± 3 LSB, whereas a 40.4 ns duration is needed for 12 bits and  $\pm$  0.5 LSB.

<span id="page-28-1"></span>

**Figure 28. Example of SAR ADC input sampling time vs accuracy**

1. The above results are obtained in the following conditions: R<sub>AIN</sub> = 1 kΩ<br>C<sub>AIN</sub>/C<sub>PCB</sub> = 2 nF<br>12-bit ADC resolution

Typical conditions of voltage, temperature, process, package, and number of ADCs running.

*[Table](#page-28-0)* 1 gives examples of sampling time for STM32H7 series with  $R_{AIN} = 1$  kΩ,  $C_{\text{AIN}}/C_{\text{PCB}}$  = 2 nF,  $V_{\text{REF+}}$  = 2 V and  $F_{\text{ADC}}$  = 20 MHz.

<span id="page-28-0"></span>



When the ADC resolution is 8 bits and the acquisition accuracy is greater than  $\pm$  1 LSB,  $T<sub>SMPL</sub>$  can be minimized to a few picoseconds due to LSB amplitude, whereas with an ADC



resolution is 16 bits and an acquisition accuracy equal to  $\pm$  0.5 LSB, T<sub>SMPL</sub> maximum value is 67.1 ns.

#### **SAR ADC conversion duration and sampling rate dependency versus SMP**

The ADC SMP parameter enables programming the duration of the ADC sampling operation to a given number of ADC clock cycles. SMP can be selected among a list of values that depends on each STM32 series (see *[Figure](#page-32-0) 29* and *[Table](#page-29-0) 2*). To match the requirements of wide frequency-range applications, SMP values approximately follow a logarithm law.

| <b>ADC SMP code</b> | <b>STM32G0</b> | <b>STM32F1</b> | STM32L4 | STM32H7 | STM32H5 |
|---------------------|----------------|----------------|---------|---------|---------|
| 0                   | 1.5            | 1.5            | 2.5     | 1.5     | 2.5     |
| 1                   | 3.5            | 7.5            | 6.5     | 2.5     | 6.5     |
| 2                   | 7.5            | 13.5           | 12.5    | 8.5     | 12.5    |
| 3                   | 12.5           | 28.5           | 24.5    | 16.5    | 24.5    |
| $\overline{4}$      | 19.5           | 41.5           | 47.5    | 32.5    | 47.5    |
| 5                   | 39.5           | 55.5           | 92.5    | 64.5    | 92.5    |
| 6                   | 79.5           | 71.5           | 247.5   | 387.5   | 247.5   |
| 7                   | 160.5          | 239.5          | 640.5   | 810.5   | 640.5   |

<span id="page-29-0"></span>**Table 2. Examples of ADC SMP selection vs STM32 Series (in ADC clock cycles)** 

The distribution of ADC SMP values is a constraint to optimize the ADC sampling time. In the following example, which is based on the STM32H7 series, some application conditions are optimized.

*[Table](#page-31-0)* 3 to *Table 7* show examples of results for STM32H7 series obtained with R<sub>AIN</sub> = 1 kΩ,  $C_{\text{AIN}}/C_{\text{PCB}}$  = 2 nF,  $V_{\text{RFF+}}$  = 2 V and  $F_{\text{ADC}}$  = 20 MHz.

*[Table](#page-29-1) 3* shows the real minimum sampling time expressed in ADC clock cycles (sampling duration / ADC clock period) corresponding to *[Table](#page-28-0) 1*.

<span id="page-29-1"></span>

| <b>Acquisition</b><br>accuracy | 8 bits | 10 bits | 12 bits | 14 bits | 16 bits |
|--------------------------------|--------|---------|---------|---------|---------|
| $± 0.5$ LSB                    |        | 6       |         | 11      | 14      |
| $± 1$ LSB                      |        | 5       |         | 10      | 13      |
| $± 2$ LSB                      |        |         | 6       | 9       |         |
| $±3$ LSB                       |        | 3       | 5       | ŏ       |         |

**Table 3. Rounded minimum sampling time vs resolution and maximum error (in ADC clock cycles)** 

For STM32H7 series, T<sub>SMPL</sub> can be programmed to the following values, through the SMP parameter: 1.5, 2.5, 8.5, 16.5, 32.5, 64.5, 387.5 or 810.5 ADC clock cycles. *[Table](#page-30-0) 4* shows the minimum SMP value required to reach various input sampling accuracies:

57

<span id="page-30-0"></span>

| ,                              |        |         |         |         |         |
|--------------------------------|--------|---------|---------|---------|---------|
| <b>Acquisition</b><br>accuracy | 8 bits | 10 bits | 12 bits | 14 bits | 16 bits |
| $± 0.5$ LSB                    | 8.5    | 8.5     | 16.5    | 16.5    | 16.5    |
| $± 1$ LSB                      | 2.5    | 8.5     | 8.5     | 16.5    | 16.5    |
| $±2$ LSB                       | 1.5    | 8.5     | 8.5     | 16.5    | 16.5    |
| $±3$ LSB                       | 1.5    | 8.5     | 8.5     | 8.5     | 16.5    |

**Table 4. Minimum SMP values vs resolution and maximum error (in ADC clock cycles)** 

*[Table](#page-30-1) 5* gives additional clock cycles between the real minimum sampling time and the corresponding minimum SMP value.

<span id="page-30-1"></span>

| ys resolution and maximum error |        |         |         |         |         |
|---------------------------------|--------|---------|---------|---------|---------|
| <b>Acquisition</b><br>accuracy  | 8 bits | 10 bits | 12 bits | 14 bits | 16 bits |
| $± 0.5$ LSB                     | 4.5    | 2.5     | 7.5     | 5.5     | 2.5     |
| $± 1$ LSB                       | 0.5    | 3.5     | 1.5     | 6.5     | 3.5     |
| $±2$ LSB                        | 1.5    | 4.5     | 2.5     | 7.5     | 5.5     |
| $± 3$ LSB                       | 1.5    | 5.5     | 3.5     | 0.5     | 5.5     |

**Table 5. Additional ADC clock cycles due to SMP vs resolution and maximum error** 

In normal application conditions, an optimized sampling time is achieved for an 8-bit ADC resolution and an accuracy greater than  $\pm$  1 LSB, while nonoptimized sampling times are obtained for a 12-bit ADC resolution and accuracy lower than ± 1 LSB, and 14-bit and 16-bit resolution with an accuracy lower than  $\pm$  3 LSB.

**[Table](#page-30-2) 6** shows the total conversion times including T<sub>SAR</sub> duration and the computed ADC output sampling rate ( $T_{SMPI}$ ). For STM32H7 series,  $T_{SAR}$  can be programmed to the following values: 4.5, 5.5, 6.5, 7.5 or 8.5 ADC clock cycles for ADC resolutions of 8-, 10-, 12-, 14-, and 16 bit resolutions.

<span id="page-30-2"></span>

| <b>Acquisition</b><br>accuracy | 8 bits | 10 bits | 12 bits | 14 bits | 16 bits |
|--------------------------------|--------|---------|---------|---------|---------|
| $± 0.5$ LSB                    | 13     | 14      | 23      | 24      | 25      |
| $± 1$ LSB                      |        | 14      | 15      | 24      | 25      |
| $± 2$ LSB                      | 6      | 14      | 15      | 24      | 25      |
| $± 3$ LSB                      | 6      | 14      | 15      | 16      | 25      |

Table 6. Minimum ADC conversion time (T<sub>SMPL</sub> + T<sub>SAR</sub>) vs resolution **and maximum error (in ADC clock cycles)** 

The maximum ADC output sampling rate for these application conditions can then be computed.



<span id="page-31-0"></span>

**Table 7. Maximum ADC output sampling rate (***MSPS***) vs resolution and maximum error** 

When the ADC resolution is 8 bits and the acquisition accuracy is above  $\pm$  2 LSB, the maximum ADC sampling rate output 3.3 MSPS, is achieved with  $R_{AIN} = 1$  k $\Omega$ ,  $C_{AIN}/C_{PCR}$  = 2 nF,  $F_{ADC}$  = 20 MHz, and typical conditions of voltage, temperature, process, package, and number of ADCs running.

When the ADC resolution is 16 bits, the ADC sampling rate is reduced to 0.8 MSPS with an acquisition accuracy lower than  $\pm$  3 LSB.

## Method for estimating the SAR ADC sampling rate (T<sub>SMPL</sub>)

A mathematical model is not accurate enough given the number of parameters and their nonlinear characteristics. Only a complex design simulation can provide a very good estimate of the minimum  $T_{SMPI}$  duration in various conditions. Such SAR ADC sampling estimation tool is available on demand.  $T_{SMPL}$  simulation results are simply postprocessed and rendered based on ADC clock frequency to achieve the desired ADC output data rate. The simulation tool performs the following functions:

- Estimation of T<sub>SMPL</sub> versus ADC frequency (see *[Figure 29](#page-32-0)*).
- Visualization of  $T_{SMPI}$  margin versus  $R_{AIN}/C_{AIN}$  values or tolerance for a given channel (see *[Figure 30](#page-32-1)*)

The tool helps selecting the correct SMP value to optimize the sampling duration for any ADC frequency range. It directly shows the output data rate that is achievable with the selected ADC resolution.





#### <span id="page-32-0"></span>Figure 29. T<sub>SMPL</sub> estimation versus ADC frequency and comparison of minimum **TSMPL duration**  for slow and fast channels with same R<sub>AIN</sub>/C<sub>AIN</sub>

1. The above results are obtained in the worst conditions of temperature, supply voltages, and process.

<span id="page-32-1"></span>



1. The above results are obtained in the worst conditions of temperature, supply voltage, and process.



## <span id="page-33-0"></span>**4.2.7 External analog buffer usage**

The use of a follower amplifier (buffer) in front of an ADC analog input reduces the resistance of the source effect because of the high input impedance of the amplifier and its very low output impedance. It isolates  $R_{AIN}$  from  $R_{ADC}$ .

However, the amplifier introduces an offset error that must be taken into account as an additional error. The used amplifier must provide a small offset error.

The amplifier speed (bandwidth and slew rate) parameter is important for designing fast signal data acquisition applications.

The amplifier in follower mode offers a very low output impedance. The ADC can then use short sampling times. However, the required sampling time must be designed also regarding the amplifier speed. The amplifier has a low output impedance due to its feedback (driving the output to be on the same voltage as the input). This feedback response has a limited speed, which is defined by the used amplifier speed. The discharged sampling capacitor is connected to the amplifier output if the ADC starts the sampling operation. The amplifier (through its feedback) starts compensating this unbalance by increasing the output driving and charging the sampling capacitor. The speed of this output driving depends on the amplifier speed (propagation of the input change to the output change). The chosen ADC sampling time must be designed to be several times longer than this amplifier propagation delay.

### <span id="page-33-1"></span>**4.2.8 Source frequency condition vs. source and parasitic capacitors**

The external capacitance of  $C_{AIN}$  does not allow the analog input voltage to be exactly the same as  $V_{\text{AIN}}$  if the capacitor is not fully charged by the analog source (see *[Figure 16.](#page-16-2)*).

If the analog input signal changes, then the analog signal frequency  $(F_{AIN})$  must be such that the time period of this analog signal is at least:  $10 \times R_{AIN} \times (C_{AIN} + C_{D}).$ 

 $T_{\text{AIN}}$  = analog signal time period = 1/ $F_{\text{AIN}}$ .

We have:  $\mathsf{T}_{\mathsf{AIN}}$   $\geq$  10  $\times$  R  $_{\mathsf{AIN}}$   $\times$  (C  $_{\mathsf{AIN}}$  + C  $_{\mathsf{P}}$ )

Therefore: 
$$
F_{\text{AIN}} \le \frac{1}{10 \times R_{\text{AIN}} \times (C_{\text{AIN}} + C_{\text{P}})}
$$

For example:

For R<sub>AIN</sub> = 25 kΩ, C<sub>AIN</sub> = 7 pF, C<sub>p</sub> = 3 pF, this gives:

$$
F_{\text{AlNmax}} = \frac{1}{10 \times 25 \times 10^{3} \times (7+3) \times 10^{-12}}
$$

Thus, the maximum frequency of the source is:  $F_{\text{AlNmax}}$  = 400 kHz .

So, for the above defined source characteristics (capacitance and resistance), the frequency of the source must not exceed 400 kHz, otherwise the ADC conversion result is not accurate.





<span id="page-34-3"></span>

Figure 31. Recommended values for R<sub>AIN</sub> and C<sub>AIN</sub> vs. source frequency F<sub>AIN</sub>

## <span id="page-34-0"></span>**4.2.9 Temperature-effect compensation**

One method is be to fully characterize the offset and gain drift and provide a lookup table in memory to correct measurement according to temperature change. This calibration involves additional costs and takes time.

The second method consists in recalibrating the ADC when the temperature change reaches a given value, by using the internal temperature sensor and the ADC watchdog.

## <span id="page-34-1"></span>**4.2.10 Minimizing injection current**

Check the application to verify whether any digital or analog input voltage can be less than  $V_{SS}$  or  $V_{SSA}$ . If it is the case, a negative injection current flows from the pins. The effect on the accuracy is greater if a digital input is close to the analog input being converted.

Negative current injection on any of the standard (nonrobust) analog input pins must be avoided, as this significantly reduces the accuracy of the conversion performed on another analog input.

It is recommended to connect a Schottky diode between  $V_{SSA}$  and the I/O pin that can give birth to the negative injection current.

The ADC accuracy is not affected by positive injection currents within the limits specified for I<sub>INJ(PIN)</sub> and ΣI<sub>INJ(PIN)</sub> (refer to the corresponding STM32 datasheet, I/O port characteristics section).

## <span id="page-34-2"></span>**4.2.11 Minimizing I/O pin crosstalk**

The noise produced by crosstalk can be reduced by shielding the analog signal by placing ground tracks across it. *[Figure](#page-35-1) 32* shows the recommended grounding between signals.



<span id="page-35-1"></span>

**Figure 32. Crosstalk between I/O pins**

## <span id="page-35-0"></span>**4.2.12 EMI-induced noise reduction**

EMI noise can be reduced by using proper shielding and layout techniques. The possible sources of emission must be physically separated from the receptors. They can be separated electrically by proper grounding and shielding.

## **Shielding technique**

Placing ground tracks alongside sensitive analog signals provides shielding on the PCB. The other side of the two-layer PCB must also have a ground plane. This prevents interference and I/O crosstalk affecting the signal (see *[Figure](#page-35-2) 33*).

Signals coming from distant locations (such as sensors) must be connected to the PCB using a shielded cable. Care must be taken to minimize the length of the paths of these types of signals on the PCB.

The shield must not be used to carry the ground reference from the sensor or analog source to the microcontroller. A separate wire must be used as the ground. The shield must be grounded at only one place near the receiver such as the analog ground of the microcontroller. Grounding the shield at both ends (source and receiver) might lead to the creation of ground loops, with the result of current flowing through the shield. In this case, the shield acts like an antenna and the purpose of the shielding is lost.

The shielding concept also applies to grounding the chassis of the application if it is metallic. And it also helps remove EMI and EMC interference. In this case, the mains earth ground is used to shield the chassis. Similarly, DC ground can be used for shielding in case of the earth ground not being available.

<span id="page-35-2"></span>





## <span id="page-36-0"></span>**4.2.13 PCB layout recommendations**

## **Separating the analog and digital layouts**

It is recommended to separate the analog and digital circuitry on the PCB (see *[Figure](#page-36-1) 34*). This also avoids tracks crossing each other. The tracks carrying digital signals may introduce high-frequency noise in analog signals because of coupling.

The digital signals produce high-frequency noise because of fast switching.

Coupling of a capacitive nature is formed due to the metal connections (tracks) separated by the dielectric provided by the PCB base (glass, ceramic or plastic).

It is recommended to use different planes for analog and digital grounds. If there is a lot of analog circuitries, then an analog ground plane is recommended. The analog ground must be placed below the analog circuitry.

<span id="page-36-1"></span>

#### **Figure 34. Separating the analog and digital layouts**

### **Separating the analog- and digital-circuit power supplies**

It is desirable to have separate analog and digital power supplies in cases where there are a lot of analog and digital circuits external to the microcontroller (see *[Figure](#page-37-0) 35*). Depending on the STM32 package, different analog and digital power supply and ground pins are available. The  $V_{DDA}/V_{REF+}$  and  $V_{DD}$  pins can be powered from separate power supplies.

When using a switching-type power supply for the digital circuitry, it is recommended to use a separate linear supply for the analog circuit. Additionally, if a lot of noise is expected on the DC power supply due to I/O switching, etc., it is recommended to use a separate supply for the analog circuit.



<span id="page-37-0"></span>

#### **Figure 35. Separating the analog and digital supplies**

It is also recommended to connect the analog and digital grounds in a star network. This means that the analog and digital grounds must be connected at only one point. This prevents the introduction of noise in the analog power supply circuit due to digital signal switching. This also prevents current surges from affecting the analog circuit.

## **Using separate PCB layers for the supply and ground**

**Two-layer PCBs** 

For two-layer PCBs, it is recommended to provide a maximum ground plane area. The power supply ( $V_{DD}$ ,  $V_{DDA}$ ) must run through thick tracks. The two layers can have their ground shorted together via multiple connections in the overlap region if the two layers feature the same ground signals. The unused PCB area can be used as the ground plane.

The other convention is to connect the unused PCB area on one layer to the positive supply  $(V_{DD})$  and the unused area on the other layer, to the ground. The advantage is a reduced inductance for power and ground signals. The maximum ground area provided for ground on the PCB results in a good shielding effect and reduces the electromagnetic induction susceptibility of the circuit.

**Multilayer PCBs** 

Wherever possible, try to use multilayer PCBs and use separate layers on the PCB for power and ground. The  $V_{DD}$  and  $V_{SS}$  pins of the various devices can be directly connected to the power planes, thus reducing the length of track needed to connect the supply and ground. Long tracks have a high-inductive effect. The analog ground can be connected at one point to this ground plane. If so, it must be close to the power supply.

A full ground plane provides good shielding and reduces the electromagnetic induction susceptibility of the circuit.

Single-layer PCBs

Single-layer PCBs are used to save cost. They can be used only in simple applications when the number of connections is very limited. It is recommended to fill the unused area with ground. Jumpers can be used to connect different parts of the PCB.



## <span id="page-38-0"></span>**4.2.14 Component placement and routing**

Place the components and route the signal traces on the PCB so as to shield analog inputs.

Components like resistors and capacitors must be connected with very short leads. Surface-mounted device (SMD) resistors and capacitors can be used. SMD capacitors can be placed close to the microcontroller for decoupling purposes.

Use wide tracks for power, otherwise, the series resistance of the tracks causes a voltage drop. Indeed, narrow power tracks have a nonnegligible finite resistance, so high load currents through them cause a voltage drop across them.

Quartz crystals must be surrounded by ground tracks/plane. The other side of the two-layer PCB below the crystal must preferably be covered by the ground plane. Most crystals have a metallic body that must be grounded. Additionally, place the crystal close to the microcontroller. A surface-mounted crystal can be used.

## <span id="page-38-1"></span>**4.3 Software methods to improve precision**

- Averaging samples:
	- Averaging decreases speed but can improve accuracy
- Digital filtering (50/60 Hz suppression from DC value)
	- A proper sampling frequency is set (the trigger from timer is useful in this case).
	- Software postprocessing is performed on sampled data (for instance, comb filter for 50 Hz noise and its harmonics suppression).
- Fast Fourier Transform (FFT) for AC measurements
	- This method allows showing harmonic parts in a measured signal.
	- It is slower due to the use of more computation power.
- ADC calibration: offset, gain, bit weight calibration

ADC calibration decreases internal ADC errors. However, the internal ADC structure must be known.

• Minimizing the internal noise generated by the CPU

The application has to be designed.

- to use minimum disturbance from the microcontroller during ADC conversion.
- to minimize digital signal changes during sampling and conversion (digital silence).

## <span id="page-38-2"></span>**4.3.1 Averaging samples**

The principle of this method is to increase ADC precision but decrease ADC conversion speed (oversampling). If the measured analog signal produces unstable ADC values, then the mean value of the given input signal can be obtained by averaging a set of values. Variation can be caused by signal noise or noise generated by the microcontroller itself (high speed digital signals capacitively coupled to the analog input signal).

Averaging is performed by choosing an appropriate number of samples to be averaged. This number depends on the required precision, minimum conversion speed and the level of other ADC errors (if another error has a greater influence on ADC precision, then increasing the number of averaging values has no effect on total measurement precision).



In some STM32 microcontrollers, averaging can be performed by using the hardware oversampling feature: the ADC performs built-in hardware averaging according to configurable parameters (number of samples to average and final right bit shift of result).

The advantage of averaging is to improve ADC precision without any hardware changes. The drawback is that the conversion speed is lower as well as the frequency response (it is equivalent to decreasing effective sampling frequency).

## <span id="page-39-0"></span>**4.3.2 Digital signal filtering**

This method uses digital signal processing techniques.

In principle, averaging is also a simple digital filter with a specific frequency response. However, if the noise frequency spectrum is known, a digital filter can be designed which minimizes noise influence and maximizes ADC frequency response. For example, if the noise in the measured signal is coming from the 50 Hz power lines, then an appropriate digital filter suppresses only the 50 Hz frequency and delivers data signal without this noise.

The disadvantage of this method is that it requires appropriate microcontroller processing power and resources: CPU speed and data/program memory usage.

## <span id="page-39-1"></span>**4.3.3 FFT for AC measurement**

In some specific cases, the application needs to know the amplitude of an AC signal with a given frequency. In this case, the effective value of an AC signal can also be obtained by using a relatively slow sampling speed (in comparison to the measured signal frequency). For example, when measuring an AC mains signal (which is near-to-sinusoidal and has relatively low harmonics content), it is sufficient to choose a sampling frequency 32 times greater than the mains frequency (50 Hz). In this case harmonics of up to, the 15th order can be obtained. The amplitude of 15th harmonics in the main signal is very small (the next order harmonics can be neglected). The calculated effective value of the mains signal is obtained with high precision because the effective values of harmonics are added to the total AC harmonic value as:

$$
U_{ef} = \sqrt{U_1^2 + U_2^2 + ... + U_n^2}
$$

So, if the 15th harmonics amplitude is only 1% (0.01) from the 1st harmonics (50 Hz), then its contribution to the total effective value is only 0.01% (because the square addition in the above equation gives:  $0.01^2 = 0.0001$ ).

The principle of this method is therefore to sample the AC signal with a known frequency and then perform postprocessing on the FFT for each measured period. Because the number of sampling points per measured signal period is small (32 points for example) then the performance needed for FFT processing is not so high (only 32-point FFT for example).

This method is well adapted for AC measurement of signals with lower distortion. The drawback is that it requires precise signal sampling:

- The frequency of the measured signal must be known and the ADC sampling frequency must be set exactly as a  $2^n$  multiplier of the measured frequency.
- The input signal frequency is measured by another method.
- The ADC sampling frequency is tuned by programming the prescaler and MCU master clock selection (if sampling is performed with an inaccurate clock an interpolation can be used to obtain samples at the required points).



## <span id="page-40-0"></span>**4.3.4 ADC calibration**

This method requires knowledge of the internal ADC structure and of how the ADC converter is implemented inside the microcontroller. This is necessary to design a physical/mathematical model of the ADC implementation.

A proper physical model (which is usually a schematic diagram) is used as a basis for describing it mathematically. From the mathematical model, each element in the model can be obtained by a set of equations (for example, resistor/capacitor values, which represent bit weights). To solve these equations, it is necessary to perform a set of practical measurements and obtain a set of solvable equations.

From the measured values and mathematical computation of the model, all the known values of model elements (resistors, voltages, capacitors,...) can be put into the schematic diagram.

As a result, instead of the ADC schematic with the designed values, an ADC schematic with the real values for a given microcontroller can be obtained.

Computed model parameters are stored in the microcontroller memory after calibration and used in postprocessing to correct ADC values.

## <span id="page-40-1"></span>**4.3.5 Minimizing internal CPU noise**

When the CPU operates, it generates a lot of internal and external signal changes, which are transferred into the ADC peripheral through capacitive coupling. This disturbance influences ADC precision (unpredictable noise due to different microcontroller operations).

To minimize influences of the CPU (and of other peripherals) on ADC, it is necessary to minimize digital signal changes during sampling and conversion time (digital silence). This is done using one of the following methods (applied during sampling and conversion time):

- Minimizing I/O pin changes
- Minimizing internal CPU changes (CPU stop, wait mode)
- Stopping clock for unnecessary peripherals (timers, communications...)

## <span id="page-40-2"></span>**4.4 High impedance source measurement**

This section describes the ADC measurement behavior of STM32 ADC when a signal source with high internal impedance is used. It explains how to design an application to reach the requested precision and provides workarounds.

## <span id="page-40-3"></span>**4.4.1 ADC input stage problem**

The ADC embedded in STM32 devices is a switched-capacitor ADC. Switched capacitors work also as sampling capacitors (see *[Section](#page-5-2) 2.1* for a detailed explanation).

When a signal comes from a voltage source with high internal impedance (for instance, 150 kΩ), an additional error can be seen in measurement results. Error signals have also been observed on the ADC input pin, as shown in *[Figure](#page-42-1) 38* (if the voltage source has zero voltage: U<sub>in</sub> = 0 V, R<sub>in</sub> = 150 kΩ, C<sub>ext</sub> = 0 pF):



<span id="page-41-0"></span>





<span id="page-41-1"></span>



## <span id="page-42-0"></span>**4.4.2 Explanation of the behavior**

The explanation of this additional pin noise and additional measurement error (in case a signal source with high internal impedance is used) comes from the internal ADC structure: its input sampling circuit.

*[Figure](#page-42-1) 38* shows a simplified schematic of the input stage (sample and hold circuit).

**Figure 38. ADC simplified schematic of input stage - sample and hold circuit**

<span id="page-42-1"></span>

The spikes (noise) present on ADC input pin during conversions are related to the sampling switch  $(S_1)$ . If the switch is closed, some charge (coming from the sample and hold capacitor  $C_{\rm sh}$  or caused by another effect) is transferred to the input pin. Then this charge starts discharging through the source impedance  $(R_{in})$ . The discharge process ends at the end of the sampling time (t<sub>S</sub>) when the switch  $S_1$  is opened. The remaining undischarged voltage remains on the capacitor  $C_{sh}$  and ADC measures this voltage. If the sampling time  $(t<sub>S</sub>)$  is too short, the remaining voltage does not drop under 0.5 LSB and ADC measurement shows an additional error. *[Figure](#page-42-2) 39* illustrates this process.



<span id="page-42-2"></span>**Figure 39. ADC input pin noise spikes from internal charge during sampling process**

Note that a nonzero external capacitance  $C_{ext}$  (parasitic pin capacitance) also exists, so during conversion time the pin capacitance is discharged through source impedance  $R_{in}$ .



## <span id="page-43-0"></span>**4.4.3 Minimizing additional errors**

#### **Workaround for high impedance sources**

To solve the additional error problem, the sampling time  $(T<sub>S</sub>)$  can be increased by configuring ADC settings in MCU firmware, so that the  $C_{sh}$  charge is discharged through the source impedance  $R_{in}$ . The time constant ( $R_{in}$  x  $C_{sh}$ ) is the reference for choosing the sampling time. To calculate the sampling time cycles, use this formula (for a maximum error of 1/2 LSB, see also *[Section](#page-24-0) 4.2.6*):

 $T_S \ge f_{ADC}$   $(R_{in} \cdot C_{sh}) \cdot ln(2^{N+1})$  [cycles]

The ADC clock  $(f_{ADC})$  is another important factor, since slowing down the ADC clock increases the sampling time.

<span id="page-43-1"></span>



If the maximum register value of the sampling time  $(T<sub>S</sub>)$  setting is reached and the problem is still present, more complex solution is needed, which is applicable also for measurements of source with extra high internal impedance (see *Section : Workaround for extra high impedance sources*).

Note that for this application, it is important to consider not only the internal sampling capacitance but also any external parasitic capacitance (in parallel to  $C_{ext}$ ), such as pin capacitance or PCB path capacitance.

Do not add any external capacitor  $(C_{ext})$  to the input pin when applying this above workaround. Its capacity increases the timing constant ( $R_{in}$  x  $C_{sh}$  ||  $C_{ext}$ ) and the problem remains.



#### **Workaround for extra high impedance sources**

This workaround combines both hardware and software changes.

#### **Hardware change**

The hardware change consists in adding a large external capacitor  $(C_{ext})$  to the input pin. The capacity size connected to the input pin must reach the value that causes the discharging of the internal sampling capacity  $C_{sh}$  to the external capacitor  $C_{ext}$  without increasing the voltage on  $C_{ext}$  to more than 0.5 LSB.

#### Example

If the internal capacitor ( $C_{sh}$  = 16 pF) is charged to full scale ( $U_{max}$ , which corresponds to 4095 LSB), then the external capacitor  $C_{ext}$  must be charged at maximum 0.5 LSB voltage level ( $U_{\text{lsb}}$ ) after discharging C<sub>sh</sub> to it. The capacity of C<sub>ext</sub> is then:

$$
C_{ext} \ge C_{sh} \cdot \frac{U_{max}}{U_{lsb}} = 16pF \cdot \frac{4095}{0.5} \approx 131nF
$$

The closest larger standard value chosen here is:  $C_{ext}$  = 150 nF.

If the internal sampling capacitor  $C_{sh}$  is not charged to full voltage range (4095 level) before sampling, the  $C_{ext}$  value can be computed by replacing "4095" in the formula above. Calculating with 4095 level gives precise measurement results also in the case of ADC input channels switching  $(C_{sh}$  was charged from different ADC input in the previous measurement).

A side effect of this hardware workaround is the cyclical charging of  $C_{\text{ext}}$  which must be taken into account. Each ADC conversion transfers the charge from  $C_{sh}$  to  $C_{ext}$ . One transfer charges the  $C_{ext}$  below 0.5 LSB, as described above, but more transfers can charge Cext to larger values if it is not discharged between two conversions. *[Figure](#page-44-0) 41* shows an example of this scenario where the ADC measurement is performed faster.



<span id="page-44-0"></span>



#### **Software change**

The side effects mentioned above can be solved by software. The objective is to create a delay to let  $C_{ext}$  discharge through  $R_{in}$  (not measure so often) giving enough "discharge time" between ADC conversions. The "discharge time"  $(t<sub>C</sub>)$  is equal to the transferred charge from C<sub>sh</sub> to C<sub>ext</sub> (charging) and from C<sub>ext</sub> to R<sub>in</sub> (discharging). The assumption is that C<sub>ext</sub>  $>> C_{\text{sh}}$ .

$$
Q_{\text{charging}} = Q_{\text{sh}} = C_{\text{sh}} \cdot U_{\text{max}}
$$

$$
Q_{discharging} = \frac{U_{lsb}}{R_{in}} \cdot \int\limits_{0}^{t_C} e^{\frac{t}{R_{in}C_{ext}}} dt
$$

where:

U<sub>lsb</sub> ....... 0.5 LSB voltage level Umax ..... 4095 LSB voltage level (worst case)  $Q_{charging} = Q_{discharging}$ 

$$
C_{sh} \cdot U_{max} = \frac{U_{lsb}}{R_{in}} \cdot \int\limits_{0}^{t_C} e^{\frac{t}{R_{in}C_{ext}}} dt
$$

Simplification of the above formula gives the final formula for the required waiting time between conversions:

$$
t_C \ = \ - (R_{in} \cdot \ C_{ext}) \cdot \ \ln \biggl[ 1 - \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}} \biggr]
$$

This final formula shows the dependency between the external capacitor  $C_{ext}$  and the required waiting time between two conversions if the precision  $U_{\text{lsb}}$  is needed.

From the same formula, the argument in the logarithm must be positive. Therefore, there is a condition for the minimal value of  $C_{ext}$ :

$$
\left[1 - \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}}\right] > 0
$$
\n
$$
1 > \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}}
$$

$$
C_{ext} > C_{sh} \cdot \frac{U_{max}}{U_{lsb}}
$$

Choosing a larger  $C_{ext}$  decreases more the time between conversions (t<sub>C</sub>).



An extra large  $C_{ext}$  ( $C_{ext}$ > $\geq C_{sh}$ ,  $\frac{2 \text{ max}}{11}$ ) enables sampling more often. However, increasing C<sub>ext</sub> limits the frequency bandwidth of the measurement signal (increasing the "external" timing constant  $R_{in}$ . C<sub>ext</sub>).  $C_{\rm sh}$ .  $\frac{U_{\rm max}}{U_{\rm max}}$ ∴ <del>P</del>max<br>U<sub>lsb</sub>

The formulas below show how to choose the optimal  $C_{ext}$  value: signal bandwidth in correlation with sample time. Signal bandwidth is characterized by an "external" timing constant, so the optimal solution is to charge  $C_{ext}$  during  $t_C$ :

$$
(R_{in} \cdot C_{ext}) = t_C
$$

$$
(R_{in} \cdot C_{ext}) = -(R_{in} \cdot C_{ext}) \cdot ln \left[1 - \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}}\right]
$$

$$
-1 = \ln \left[ 1 - \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}} \right]
$$

$$
e^{-1} \ = \ 1 - \frac{C_{sh}}{C_{ext}} \frac{U_{max}}{U_{lsb}}
$$

After simplification we obtain the final formula for optimal  $C_{ext}$ :

$$
C_{ext} = \frac{C_{sh} \frac{U_{max}}{U_{lsb}}}{1 - e^{-1}} \approx 1, 58 \cdot C_{sh} \frac{U_{max}}{U_{lsb}}
$$

and the corresponding waiting time between conversions:

$$
t_C \approx -(R_{in} \cdot C_{ext}) \cdot ln\left[1 - \frac{1}{1, 58}\right] \approx (R_{in} \cdot C_{ext})
$$

Practically the firmware must not program the ADC in continuous mode but only in single mode and must ensure that there is a time gap between conversions with duration equal to  $t<sub>C</sub>$ . This adding of waiting time is the software change, which must be applied together with the hardware change (adding an external capacitor  $C_{ext}$ ).

Without implementation of  $t_C$  waiting time in software (for instance, running a conversion just after the first one) the external capacitor  $C_{ext}$  is cyclically charged from the  $C_{sh}$  capacitor. After a lot of cycles, the voltage on  $C_{ext}$  reaches a quite high error value (as previously shown in *[Figure](#page-44-0) 41*).

A practical example of implementation for STM32L1 ADC is shown below:





 $U_{\text{max}}$  = 4095 LSB ..... ADC property  $U_{\text{lsh}}$  = 0.5 LSB  $\ldots$  required precision

$$
C_{ext} = 1,~58 \cdot ~C_{sh} \frac{U_{max}}{U_{lsb}} = 1,~58 \cdot ~16pF \cdot ~\frac{4095}{0.5} \approx ~207nF \Rightarrow 220nF
$$

$$
t_C = -(R_{in} - C_{ext}) - ln\bigg[1 - \frac{C_{sh} U_{max}}{C_{ext} U_{lsb}}\bigg] = -(150k\Omega - 220nF) - ln\bigg[1 - \frac{16pF}{220nF}\frac{4095}{0.5}\bigg] \approx 29879 \mu s \Rightarrow 30ms
$$

### <span id="page-47-0"></span>**4.4.4 Source of described problem - ADC design**

The following sections list some possible causes for the charging of the internal sampling capacitor  $C_{\rm sh}$ . This is not an exhaustive list; only the main possible sources of the ADC design are mentioned.

#### **Parasitic switch capacitance effect**

The sampling switch inside ADC sampling circuit (see *[Figure](#page-42-1) 38*) is not ideal. In reality the sample and hold switch  $(S_1)$  is designed as 2 transistors (PMOS and NMOS, see *[Figure](#page-47-1) 42*):

<span id="page-47-1"></span>

**Figure 42. Implementation of sampling switch**

The switch is controlled by the gate voltages of transistors (inverted signal on PMOS transistor). This design is a standard bidirectional switch (for rail to rail range of input  $U_{in}$ voltages). Both transistors have parasitic capacitances between gate and source.

If those capacitances are charged (close to the switch), then their charge can be transferred to the sampling capacitor (see *[Figure](#page-48-0) 43*).



<span id="page-48-0"></span>

**Figure 43. Parasitic capacitances of sampling switch**

This charging and discharging currents (PMOS and NMOS asymmetric capacitances) can cause charge transfer to sampling capacitor  $C_{\text{sh}}$ .

## **Internal charging of the sampling capacitor**

It is possible that after the conversion process (successive approximation process in SAR type of ADC) the sample and hold capacitor  $C_{sh}$  is charged to some voltage. The reason can be:

- Some leakage current to C<sub>sh</sub> (parasitic current inside ADC structure, see *[Figure 44](#page-48-1)*).
- Residual charge transfer from the switches when the ADC structure is switched back to the default state before the next conversion.
- Other reasons (related to internal ADC parasitic structures).

<span id="page-48-1"></span>

#### **Figure 44. Parasitic current example inside ADC structure**



## <span id="page-49-0"></span>**5 Conclusion**

This application note describes the main ADC errors and then methods and application design rules to minimize STM32 microcontroller ADC errors and obtain the best ADC accuracy.

The choice of method depends on the application requirements and is always a compromise between speed, precision, enough computation power and design topology. The published methods lead to a precision improvement and are optimized for the design of an ADC converter using the SAR (successive approximation register) principle.



# <span id="page-50-0"></span>**6 Revision history**

<span id="page-50-1"></span>





| Table 8. Document revision history |                 |                                                                                                                                                                                                                                   |
|------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Date</b>                        | <b>Revision</b> | <b>Changes</b>                                                                                                                                                                                                                    |
| 31-May-2021                        | 7               | Updated conversion results corresponding to 1.9998 V and 2.0014 V<br>analog input voltage in Section 3.1.3: Differential linearity error.                                                                                         |
|                                    |                 | Replaced 4095 by 4096 LSB in the equations used to calculate the<br>converted value in Section 3.2.1: Reference voltage noise.                                                                                                    |
|                                    |                 | Updated equations used to calculate the digital code and the digital<br>output in Section 3.2.2: Reference voltage / power supply regulation.                                                                                     |
|                                    |                 | Section 3.2.6: ADC dynamic range bad match for maximum input<br>signal amplitude: changed maximum value converted by the ADC to<br>3103 and updated Figure 14: Input signal amplitude vs. ADC dynamic<br>range (VREF+ = $3.3$ V). |
|                                    |                 | Updated Figure 23: Selecting the reference voltage and Figure 24:<br>Preamplification.                                                                                                                                            |
|                                    |                 | Changed 4096 to 4095 LSB in Section: Workaround for extra high<br>impedance sources                                                                                                                                               |
| 10-Jan-2022                        | 8               | Formula used to calculate LSB made generic in Section 3: ADC<br>errors.                                                                                                                                                           |
|                                    |                 | Removed the figure:                                                                                                                                                                                                               |
|                                    |                 | SMP clock cycles vs STM32 Series.                                                                                                                                                                                                 |
|                                    |                 | Updated the following elements:                                                                                                                                                                                                   |
|                                    |                 | Section : Introduction                                                                                                                                                                                                            |
|                                    |                 | Section 4.2.8: Source frequency condition vs. source and parasitic<br>capacitors                                                                                                                                                  |
| 22-Aug-2023                        | 9               | Table 2: ADC SMP selection vs STM32 Series (in ADC clock cycles).                                                                                                                                                                 |
|                                    |                 | Table 4.4.3: Minimizing additional errors                                                                                                                                                                                         |
|                                    |                 | Table 8: Negative offset error representation.                                                                                                                                                                                    |
|                                    |                 | Table 4.2.2: Reference voltage / power supply regulation                                                                                                                                                                          |
|                                    |                 | Table 4.2.5: Matching the ADC dynamic range to the maximum signal<br>amplitude                                                                                                                                                    |
|                                    |                 | Updated the whole document with minor changes.                                                                                                                                                                                    |
| 25-Oct-2024                        | 10              | Updated:                                                                                                                                                                                                                          |
|                                    |                 | - Figure 8: Negative offset error representation                                                                                                                                                                                  |
|                                    |                 | - Note for Figure 5: Step 2: If MSB = 0, then compare with $\frac{1}{4}$ VREF<br>and Figure 6: Step 2: If $MSB = 1$ , then compare with $\frac{3}{4}VREF$                                                                         |
|                                    |                 | - Figure 20: Power supply and reference decoupling for 100- and<br>144-pin packages                                                                                                                                               |
|                                    |                 | - Figure 21: Power supply decoupling for 36-, 48- and 64-pin<br>packages                                                                                                                                                          |

**Table 8. Document revision history** 





#### **IMPORTANT NOTICE – PLEASE READ CAREFULLY**

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgment.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. For additional information about ST trademarks, please refer to *www.st.com/trademarks*. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2024 STMicroelectronics – All rights reserved



<span id="page-52-0"></span>AN2834 Rev 10 53/53