打印
[APM32F4]

【APM32F411V Tiny Board测评】ADC变换

[复制链接]
622|1
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
1、APM32F411V Tiny 的ADC功能是转换模拟信号为数字信号,这个是众多产品所用传感器的基础,如自动计量秤等,都是这样安排的。
在ADC开发的过程中,是读取0~Vdd的电压并进行转换,这里Vdd=3.3V,超过这个范围的电压都需要进行电压变换,防止对电路的冲击和损坏。
2、根据范例代码启动ADC连续变换的工程
void ADC_Isr(void)
{
    uint16_t adcData = 0;
    uint16_t voltage = 0;

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

    /* Enable GPIOA clock */
    RCM_EnableAHB1PeriphClock(RCM_AHB1_PERIPH_GPIOA);

    /* ADC channel 0 configuration */
    GPIO_ConfigStructInit(&gpioConfig);
    gpioConfig.mode    = GPIO_MODE_AN;
    gpioConfig.pupd    = GPIO_PUPD_NOPULL;
    gpioConfig.pin     = GPIO_PIN_0;
    GPIO_Config(GPIOA, &gpioConfig);

    /* Enable ADC clock */
    RCM_EnableAPB2PeriphClock(RCM_APB2_PERIPH_ADC1);

    /* ADC configuration */
    ADC_Reset();
    ADC_ConfigStructInit(&adcConfig);
    adcConfig.resolution          = ADC_RESOLUTION_12BIT;
    adcConfig.continuousConvMode  = ENABLE;
    adcConfig.dataAlign           = ADC_DATA_ALIGN_RIGHT;
    adcConfig.extTrigEdge         = ADC_EXT_TRIG_EDGE_NONE;
    adcConfig.scanConvMode        = DISABLE;
    ADC_Config(ADC1, &adcConfig);

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

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

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

    /* NVIC configuration */
    NVIC_EnableIRQRequest(ADC_IRQn, 1, 1);

    /* Enable ADC */
    ADC_Enable(ADC1);

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

int main(void)
{
    USART_Config_T usartConfigStruct;

    /* Configures LED2 and LED3 */
    APM_LEDInit(LED2);
    APM_LEDInit(LED3);

    /* USART configuration */
    USART_ConfigStructInit(&usartConfigStruct);
    usartConfigStruct.baudRate      = 115200;
    usartConfigStruct.mode          = USART_MODE_TX_RX;
    usartConfigStruct.parity        = USART_PARITY_NONE;
    usartConfigStruct.stopBits      = USART_STOP_BIT_1;
    usartConfigStruct.wordLength    = USART_WORD_LEN_8B;
    usartConfigStruct.hardwareFlow  = USART_HARDWARE_FLOW_NONE;

    /* COM1 init*/
    APM_COMInit(COM1, &usartConfigStruct);

    /* ADC1 initialization */
    ADC_Init();

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


使用特权

评论回复
沙发
szt1993| | 2024-5-23 17:24 | 只看该作者
ADC变换非常适用模拟量转数字进行数据分析

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

33

主题

109

帖子

1

粉丝