ADC:将模拟信号转换为数字信号
A/D转换通常包括以下四个基本过程:
-
采样(Sampling):在采样阶段,模拟信号在特定的时间间隔被采样,产生一系列离散的模拟值。这个过程需要满足奈奎斯特定理,即采样频率必须至少是信号最高频率的两倍,以避免混叠现象。
-
保持(Hold):采样得到的模拟值需要在量化之前保持稳定。在保持阶段,使用保持电路(如采样保持放大器)来保持采样瞬间的模拟电压值不变,直到量化过程完成。
-
量化(Quantization):量化是将保持的模拟信号值转换为数字形式的过程。这个过程涉及到将连续的模拟信号值映射到有限数量的离散数值上。量化过程会产生量化误差,这是A/D转换中的一个关键因素,影响转换的精度。
-
编码(Encoding):在编码阶段,量化后的离散数值被转换成二进制代码,这通常是一个二进制数,表示数字信号的值。编码过程决定了A/D转换器的分辨率,即它可以区分的最小信号变化
数据对齐:
数据右对齐(建议使用):即数据向又考靠,多出来的高位补零;
数据左对齐;数据向左移,底位多出来补零;(可以用来裁剪分辨率);
STM32 ADC采样的总转换时间:
Tconv=采样时间+12.5个ADC周期;
#include "ADC.h"
#include "stm32f10x.h" // Device header
//读取单通道,扫描ADC的值
void ADC1_Init(void){
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//分频
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Mode=GPIO_Pin_3;
GPIO_InitStructure.GPIO_Pin=GPIO_Mode_AIN;//在AIN模式下,GPIO是无效的,不适用于数字的数字的输入,或输出,这是由于AIN是专门用于模拟信号的输入。
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA,&GPIO_InitStructure);
//选择规则组的输入通道,补充菜单,单通道;
ADC_RegularChannelConfig(ADC1,ADC_Channel_0,1,ADC_SampleTime_7Cycles5);
ADC_InitTypeDef ADC_InitStructure;
ADC_InitStructure.ADC_ContinuousConvMode=DISABLE;
ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;
ADC_InitStructure.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_Mode=ADC_Mode_Independent;
ADC_InitStructure.ADC_NbrOfChannel=1;
ADC_InitStructure.ADC_ScanConvMode=DISABLE;
ADC_Init(ADC1,&ADC_InitStructure);
ADC_Cmd(ADC1,ENABLE);//开启电源
ADC_ResetCalibration(ADC1);//复位校准
while(ADC_GetResetCalibrationStatus(ADC1)==SET);//ADC_GetCalibrationStatus(ADC1)返回复位校准的状态;加上一个while循环,等待复位完成
ADC_StartCalibration(ADC1);//校准
while(ADC_GetCalibrationStatus(ADC1)==SET);
}
uint16_t ADC1_GetValue(void)
{
ADC_SoftwareStartConvCmd(ADC1,ENABLE);//开始进行转换
while(ADC_GetFlagStatus(ADC1,ADC_FLAG_STRT)==RESET);//通过ADC_GetFlagStatus返回的标准位知道是否转换完成,具体可查看数据手册
return ADC_GetConversionValue(ADC1);//返回读取到的值;
}
#include "ADC.h"
#include "stm32f10x.h" // Device header
//读取单通道,连续转换,非扫描模式,即自己不断刷新ADC的值
void ADC1_Init(void){
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//分频
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Mode=GPIO_Pin_3;
GPIO_InitStructure.GPIO_Pin=GPIO_Mode_AIN;//在AIN模式下,GPIO是无效的,不适用于数字的数字的输入,或输出,这是由于AIN是专门用于模拟信号的输入。
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA,&GPIO_InitStructure);
//选择规则组的输入通道,补充菜单,单通道;
ADC_RegularChannelConfig(ADC1,ADC_Channel_0,1,ADC_SampleTime_7Cycles5);
ADC_InitTypeDef ADC_InitStructure;
ADC_InitStructure.ADC_ContinuousConvMode=ENABLE;
ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;
ADC_InitStructure.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_Mode=ADC_Mode_Independent;
ADC_InitStructure.ADC_NbrOfChannel=1;
ADC_InitStructure.ADC_ScanConvMode=DISABLE;
ADC_Init(ADC1,&ADC_InitStructure);
ADC_Cmd(ADC1,ENABLE);//开启电源
ADC_ResetCalibration(ADC1);//复位校准
while(ADC_GetResetCalibrationStatus(ADC1)==SET);//ADC_GetCalibrationStatus(ADC1)返回复位校准的状态;加上一个while循环,等待复位完成
ADC_StartCalibration(ADC1);//校准
while(ADC_GetCalibrationStatus(ADC1)==SET);
ADC_SoftwareStartConvCmd(ADC1,ENABLE);//开始进行转换
}
uint16_t ADC1_GetValue(void)
{
return ADC_GetConversionValue(ADC1);//返回读取到的值;
}