173 2438 5004
KEROS加密芯片——品牌直销 | 免费样品 | 技术支持
当前位置:网站首页 > 资讯中心 正文 资讯中心

stm32多通道ad采样pcb

keros@mark 2023-03-18 资讯中心

请问STM32的ADC,对于指定通道如何实现多次采样后再将AD值通过DMA传入内存

多次采集取平均值即可,给你个我写的四通道转换,想更平稳的话可以在条件允许的情况下简单的用下递推平均滤波

/*********************************************************************************

 * 文件名  :ADC.c

 * 描述    :ADC模块

 * 库版本  :ST3.5.0   

 * 编写时间:2013年12月3日

 * 编写人  :LiuHui

 *

 *

 * 修改时间:2013年7月8

 * 修改内容:

 *          @1更改ADC通道为PC0~3

 *          @2加入过采样,提高精度减小波动 

 *  @!!!!

 *  程序在开发板和核心板上运行完全正常,放到SD板上ADC_ConvertedValue[1]总是等于ADC_ConvertedValue[0]

 *  原因未查明,初步判断为DMA问题,使用SD卡型时勿用ADC_ConvertedValue[1]

 *  原因现已查明为SD板问题  

 *  @!!!!

*/

#include "system.h"

#include "ADC.h"

vu16 ADC_ConvertedValue[Sample_Num][Channel_Num];

void ADC_DMA_Config(void)

{

 DMA_InitTypeDef DMA_InitStructure;

             

 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);

 DMA_DeInit(DMA1_Channel1);

 DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)ADC1-DR;

 DMA_InitStructure.DMA_MemoryBaseAddr = (u32)ADC_ConvertedValue;

 DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;

 DMA_InitStructure.DMA_BufferSize = Sample_Num*Channel_Num;

 DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;//外设地址不变

 DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;//内存地址递增

 DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;

 DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;

 DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;

 DMA_InitStructure.DMA_Priority = DMA_Priority_High;

 DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;

 DMA_Init(DMA1_Channel1, DMA_InitStructure);

 DMA_Cmd(DMA1_Channel1,ENABLE);

}

void ADC1_Config(void)

{

 GPIO_InitTypeDef GPIO_InitStructure;

 ADC_InitTypeDef ADC_InitStructure;

 

 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);

 

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;

 GPIO_Init(GPIOC, GPIO_InitStructure);

 ADC_DMA_Config();

 

 RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);

// ADC_DeInit(ADC1);

 ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;//ADC1和ADC2工作在独立模式

 ADC_InitStructure.ADC_ScanConvMode = ENABLE;//多通道

 ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;//连续转换

 ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;//软件启动转换

 ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//转换结果右对齐

 ADC_InitStructure.ADC_NbrOfChannel = Channel_Num;//通道数目

 ADC_Init(ADC1, ADC_InitStructure); 

// ADC_TempSensorVrefintCmd(ENABLE);//使能片内温度传感器

 

 RCC_ADCCLKConfig(RCC_PCLK2_Div6); //PCLK 6分频

 ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_55Cycles5);//通道,转换次序,转换时间

 ADC_RegularChannelConfig(ADC1, ADC_Channel_11, 2, ADC_SampleTime_55Cycles5);

 ADC_RegularChannelConfig(ADC1, ADC_Channel_12, 3, ADC_SampleTime_55Cycles5);

 ADC_RegularChannelConfig(ADC1, ADC_Channel_13, 4, ADC_SampleTime_55Cycles5);

// ADC_RegularChannelConfig(ADC1, ADC_Channel_16, 6, ADC_SampleTime_239Cycles5);

 

 ADC_DMACmd(ADC1, ENABLE);

 

 ADC_Cmd(ADC1, ENABLE);

 ADC_ResetCalibration(ADC1);

 while(ADC_GetResetCalibrationStatus(ADC1));

 ADC_StartCalibration(ADC1);//开始校准

 while(ADC_GetCalibrationStatus(ADC1));

 ADC_SoftwareStartConvCmd(ADC1, ENABLE);//使能ADC的软件转换启动功能

}

uint16_t ReadADCAverageValue(uint16_t Channel)

{

 uint8_t i;

 uint32_t sum = 0;

 for(i=0; iSample_Num; i++)

 {

  sum+=ADC_ConvertedValue[i][Channel];

 }

 return (sum/Sample_Num);

}

头文件

#ifndef __ADC_H

#define __ADC_H

/*使用示例:

*

 printf("%d\r\n",ADC_ConvertedValue[0]);

 printf("%d\r\n",ADC_ConvertedValue[1]);

 printf("%d\r\n",ADC_ConvertedValue[2]);

 printf("о?:%f\r\n",(1.43-(ADC_ConvertedValue[3]*3.3/4096))/0.0043+25);

*

 sprintf(ch,"AD0 Value Is:%5d.",ADC_ConvertedValue[0]);

 printf("%s",ch);

 LCD_ShowString(20,20,(uint8_t*)ch,Color[i]);

 sprintf(ch,"AD1 Value Is:%5d.",ADC_ConvertedValue[1]);

 printf("%s",ch);

 LCD_ShowString(20,40,(uint8_t*)ch,Color[i]);

 sprintf(ch,"AD2 Value Is:%5d.",ADC_ConvertedValue[2]);

 printf("%s",ch);

 LCD_ShowString(20,60,(uint8_t*)ch,Color[i]);

 sprintf(ch,"AD3 Value Is:%5d.",ADC_ConvertedValue[3]);

 printf("%s",ch);

 LCD_ShowString(20,80,(uint8_t*)ch,Color[i]);

*/

#define Channel_Num  4

#define Sample_Num  10

extern vu16 ADC_ConvertedValue[Sample_Num][Channel_Num];

void ADC1_Config(void);

uint16_t ReadADCAverageValue(uint16_t Channel);

#endif

STM32系统如何实现多通道AD采样

之前答过一个类似的……

用库函数的话有这么句……

ADC_RegularChannelConfig(ADC1,ADC_Channel_3, 1,ADC_SampleTime_1Cycles5);

ADC_RegularChannelConfig(ADC1,ADC_Channel_2, 2,ADC_SampleTime_1Cycles5);

ADC_RegularChannelConfig(ADC1,ADC_Channel_5, 3,ADC_SampleTime_1Cycles5);

那个ADC_Channel_x就是通道,然后逗号后面的1,2,3就是采样顺序,意思就是ADC1按照通道3,2,5的顺序采样……

如何用stm32进行AD采样

建议先详细阅读stm32的Datasheet,如果还觉得不好下手,找一个例程学习学习(这样的资源网上很多,另外,如果是初学,建议买一块开发板,附带的例程很丰富)。

至于AD转换,本身无非是对寄存器的读写操作。注意事项主要有:

1、根据被测信号带宽,采用合理的采样率,工程应用一般建议采样率为信号带宽的4~10倍。

2、外部信号调理电路将在很大程度上决定测量的准确度,不容忽视。

3、读取信号需要经过相关变换才能得到实际测量值,因此,需要熟悉AD的数据格式。

stm32用两路adc

#define Channel_Num 2

#define Sample_Num 10

vu16 ADC_ConvertedValue[Sample_Num][Channel_Num];

void ADC_DMA_Config(void)

{

DMA_InitTypeDef DMA_InitStructure;

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);

DMA_DeInit(DMA1_Channel1);

DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)ADC1-DR;

DMA_InitStructure.DMA_MemoryBaseAddr = (u32)ADC_ConvertedValue;

DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;

DMA_InitStructure.DMA_BufferSize = Sample_Num*Channel_Num;

DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;//外设地址不变

DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;//内存地址递增

DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;

DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;

DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;

DMA_InitStructure.DMA_Priority = DMA_Priority_High;

DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;

DMA_Init(DMA1_Channel1, DMA_InitStructure);

DMA_Cmd(DMA1_Channel1,ENABLE);

}

void ADC1_Config(void)

{

GPIO_InitTypeDef GPIO_InitStructure;

ADC_InitTypeDef ADC_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;

GPIO_Init(GPIOA, GPIO_InitStructure);

ADC_DMA_Config();

RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);

// ADC_DeInit(ADC1);

ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;//ADC1和ADC2工作在独立模式

ADC_InitStructure.ADC_ScanConvMode = ENABLE;//多通道

ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;//连续转换

ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;//软件启动转换

ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//转换结果右对齐

ADC_InitStructure.ADC_NbrOfChannel = Channel_Num;//通道数目

ADC_Init(ADC1, ADC_InitStructure);

// ADC_TempSensorVrefintCmd(ENABLE);//使能片内温度传感器

RCC_ADCCLKConfig(RCC_PCLK2_Div6); //PCLK 6分频

//通道,转换次序,转换时间

ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_55Cycles5);

ADC_RegularChannelConfig(ADC1, ADC_Channel_2, 2, ADC_SampleTime_55Cycles5);

ADC_DMACmd(ADC1, ENABLE);

ADC_Cmd(ADC1, ENABLE);

ADC_ResetCalibration(ADC1);

while(ADC_GetResetCalibrationStatus(ADC1));

ADC_StartCalibration(ADC1);//开始校准

while(ADC_GetCalibrationStatus(ADC1));

ADC_SoftwareStartConvCmd(ADC1, ENABLE);//使能ADC的软件转换启动功能

}

uint16_t ReadADCAverageValue(uint16_t Channel)

{

uint8_t i;

uint32_t sum = 0;

for(i=0; iSample_Num; i++)

{

sum+=ADC_ConvertedValue[i][Channel];

}

return (sum/Sample_Num);

}

stm32 ADC的通道与引脚是如何对应的

stm32ADC的通道对应引脚如下:

通道0对应PA0,通道1对应PA1,通道2对应PA2,通道3对应PA3,以此类推。

默认选项包括PA0的foot,ADC123_IN0,这意味着当PA0进行ADC采集引脚时,可以使用ADC1,2,3模块的channel0。

同样PA1的ADC123_IN1意味着PA1可以作为ADC1,2,3模块的通道1。

具体来说,PB0的默认选项是ADC12_IN8,所以PB0只能在ADC1的通道8和2个模块上使用,不能在ADC3模块的通道8上使用。

扩展资料:

STM32之ADC通道顺序设置:

1.在使用STM32的ADC多通道采样raid时,需要为所使用的每个通道配置相应的转换顺序和采样时间。

2.参数秩为通道的到道采样顺序。例如,如果通道10的秩设置为1,则表示在ADC中采样的第一个通道为ADC10。

3.如果通道ADC10、ADC11、ADC12和ADC13的通道数设置相同,那么DMA输出到内存的4个通道的值将是不确定的。

4.设置好信道采样序列后,DMA终端可以准确输出各信道的采样值。

本文标签:stm32多通道ad采样pcb

产品列表
产品封装
友情链接