[APM32F4] 【APM32F411V Tiny Board测评】ADC变换

[复制链接]
981|1
 楼主| 北方西门吹雪 发表于 2024-5-17 09:24 | 显示全部楼层 |阅读模式
1、APM32F411V Tiny 的ADC功能是转换模拟信号为数字信号,这个是众多产品所用传感器的基础,如自动计量秤等,都是这样安排的。
在ADC开发的过程中,是读取0~Vdd的电压并进行转换,这里Vdd=3.3V,超过这个范围的电压都需要进行电压变换,防止对电路的冲击和损坏。
2、根据范例代码启动ADC连续变换的工程
  1. void ADC_Isr(void)
  2. {
  3.     uint16_t adcData = 0;
  4.     uint16_t voltage = 0;

  5.     if (ADC_ReadStatusFlag(ADC1, ADC_FLAG_EOC))
  6.     {
  7.         ADC_ClearStatusFlag(ADC1, ADC_FLAG_EOC);
  8.         adcData = ADC_ReadConversionValue(ADC1);
  9.         voltage = (adcData*3300)/4095;
  10. printf("\r\n voltage : %d mV\r\n", voltage);
  11.     }
  12. }
这个是核心代码,使用中断调用,中断在程序开始就使能,在捕捉到中断信号后就开启一轮读取,在读取的过程需要闭锁中断,保证能够完整读完一个数据,避免再次中断破坏读取过程。
这个ADC是采用逐步逼近法读取的,可以看到最大电压3300mV,读取精度是4096,也就是12位的精度。
使用ADC_ReadConversionValue读取ADC1通道的数据后,再转换成对应的电压值,通过USART1打印出来.
3、ADC初始化
  1. void ADC_Init(void)
  2. {
  3.     GPIO_Config_T   gpioConfig;
  4.     ADC_Config_T    adcConfig;
  5.     ADC_CommonConfig_T  adcCommonConfig;

  6.     /* Enable GPIOA clock */
  7.     RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOA);

  8.     /* ADC channel 0 configuration */
  9.     GPIO_ConfigStructInit(&gpioConfig);
  10.     gpioConfig.mode    = GPIO_MODE_AN;
  11.     gpioConfig.pupd    = GPIO_PUPD_NOPULL;
  12.     gpioConfig.pin     = GPIO_PIN_0;
  13.     GPIO_Config(GPIOA, &gpioConfig);

  14.     /* Enable ADC clock */
  15.     RCM_EnableAPB2PeriphClock(RCM_APB2_PERIPH_ADC1);

  16.     /* ADC configuration */
  17.     ADC_Reset();
  18.     ADC_ConfigStructInit(&adcConfig);
  19.     adcConfig.resolution          = ADC_RESOLUTION_12BIT;
  20.     adcConfig.continuousConvMode  = ENABLE;
  21.     adcConfig.dataAlign           = ADC_DATA_ALIGN_RIGHT;
  22.     adcConfig.extTrigEdge         = ADC_EXT_TRIG_EDGE_NONE;
  23.     adcConfig.scanConvMode        = DISABLE;
  24.     ADC_Config(ADC1, &adcConfig);

  25.     ADC_CommonConfigStructInit(&adcCommonConfig);
  26.     /*Set ADC Clock Prescaler. ADC_Clock = APB2_Clock/4, 84/4=21MHz*/
  27.     adcCommonConfig.prescaler = ADC_PRESCALER_DIV4;
  28.     ADC_CommonConfig(&adcCommonConfig);

  29.     /* ADC channel 0 Convert configuration */
  30.     ADC_ConfigRegularChannel(ADC1, ADC_CHANNEL_0, 1, ADC_SAMPLETIME_112CYCLES);

  31.     /* Enable complete conversion interupt */
  32.     ADC_EnableInterrupt(ADC1, ADC_INT_EOC);

  33.     /* NVIC configuration */
  34.     NVIC_EnableIRQRequest(ADC_IRQn, 1, 1);

  35.     /* Enable ADC */
  36.     ADC_Enable(ADC1);

  37.     /* ADC start conversion */
  38.     ADC_SoftwareStartConv(ADC1);
  39. }
在上面的初始化中,需要设定全部的配置参数,其中ADC_RESOLUTION_12BIT就是按照12位精度配置读取的数值,
这个过程采用的ADC1引脚是GPIO_PIN_0,也是需要根据实际连接的位置设定的。
其他参数如果不是特别需要都可以保持不变,主要是中断使能,波形捕捉点等参数。
4. 项目启动
MDK范例工程如下,编译并下载
1.PNG
  1. int main(void)
  2. {
  3.     USART_Config_T usartConfigStruct;

  4.     /* Configures LED2 and LED3 */
  5.     APM_LEDInit(LED2);
  6.     APM_LEDInit(LED3);

  7.     /* USART configuration */
  8.     USART_ConfigStructInit(&usartConfigStruct);
  9.     usartConfigStruct.baudRate      = 115200;
  10.     usartConfigStruct.mode          = USART_MODE_TX_RX;
  11.     usartConfigStruct.parity        = USART_PARITY_NONE;
  12.     usartConfigStruct.stopBits      = USART_STOP_BIT_1;
  13.     usartConfigStruct.wordLength    = USART_WORD_LEN_8B;
  14.     usartConfigStruct.hardwareFlow  = USART_HARDWARE_FLOW_NONE;

  15.     /* COM1 init*/
  16.     APM_COMInit(COM1, &usartConfigStruct);

  17.     /* ADC1 initialization */
  18.     ADC_Init();

  19.     while (1)                       
  20.     {
  21.     }
  22. }
这个主要是配置了USART输出显示,有关ADC的变换都在上述函数中定义完成了
运行效果如下
2.PNG

szt1993 发表于 2024-5-23 17:24 | 显示全部楼层
ADC变换非常适用模拟量转数字进行数据分析
您需要登录后才可以回帖 登录 | 注册

本版积分规则

40

主题

125

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部