2020-11-10 10:12 PM
Hi I am working on a small project where I need to sample couple of ADC channels.
I am using STM32F405RG. ADC1 is running in continuous and scan mode with DMA. I am using ping pong buffers to send ADC data through USART.
After gathering some data I plot them in MATLAB.
Problem is that there are random spikes in my ADC values an example is shown below.
X axis is Seconds, Y axis is voltage. Graph belongs to an ADC channel where approximately 2.6 volts needs to be read.
Has anyone encountered this ?
2020-11-10 10:43 PM
The scale is a bit out of proportion, albeit 150mV is not just noise.
What are your input parameters and ADC settings (input impedance, sampling time) ?
Is Vdda kept separate from Vdd, and properly filtered/stabilized ?
Have you tried to observe it (Vdda) simultaneously with the ADC values on a scope ?
2020-11-10 11:19 PM
This is most likely consequence of switching of the sampling capacitor.
JW
2020-11-11 02:02 AM
I set ADC input impedance according to reference manual formula which resulted in Rin = 22kohms. Overall sampling frequency is 200ksps so for 8 channels 25ksps/ch. There is ferrite bead between Vdda and Vcc and recommended capacitors between Vdda and ground. I measured both Vcc and Vdda they seem to be ok. I measured Vdda there are no voltage dipping when sampling.
2020-11-11 02:04 AM
Can 22kohms input impedance with switching cap cause this ?
2020-11-11 02:16 AM
That does not sound correct to me.
The input must be capable of fully charging (or discharging) the S&H capacitor over the sum input impedance in the given sample time.
A simple RC network as first-order approximation.
I would expect a one order of magnitude smaller Rin.
2020-11-11 02:22 AM
Well, APB2 Clock is 64Mhz divided by ADCPRE = 2 results in 32MHz. 28Clock cycle is selected and with 12 bit ADC total clock cycle is 40. 32Mhz/40 = 800kHz but I am triggering ADC with Timer which is set to 200kHz. I am calculating Rin according to set ADC values.
2020-11-11 04:11 AM
Correct me if I am wrong but noise seems to be random. If this was due to switching capacitor wouldnt be this periodic?
2020-11-11 10:59 PM
> 28Clock cycle is selected
The sampling capacitor is switched to input signal source for those 28 clock cycles, i.e. less than 1us. The signal source must be capable of fully charging that capacitor in that time.
If the above picture is output of ADC rather than voltage on the pin observed by oscilloscope, it still may be also other reasons mentioned by Ozone.
JW
2020-11-12 01:40 AM
I have increased the sampling time to124 cycles and spikes still occur. I am confused.