stm32标准库——ADC

ADC:将模拟信号转换为数字信号

A/D转换通常包括以下四个基本过程:

  1. 采样(Sampling):在采样阶段,模拟信号在特定的时间间隔被采样,产生一系列离散的模拟值。这个过程需要满足奈奎斯特定理,即采样频率必须至少是信号最高频率的两倍,以避免混叠现象。

  2. 保持(Hold):采样得到的模拟值需要在量化之前保持稳定。在保持阶段,使用保持电路(如采样保持放大器)来保持采样瞬间的模拟电压值不变,直到量化过程完成。

  3. 量化(Quantization):量化是将保持的模拟信号值转换为数字形式的过程。这个过程涉及到将连续的模拟信号值映射到有限数量的离散数值上。量化过程会产生量化误差,这是A/D转换中的一个关键因素,影响转换的精度。

  4. 编码(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);//返回读取到的值;

}

  • 9
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要使用STM32标准库读取ADC,你需要按照以下步骤进行操作: 1. 配置ADC通道和GPIO引脚:首先,使用GPIO初始化函数将要使用的引脚配置为模拟输入模式。然后,配置ADC通道,选择要使用的ADC通道和采样时间。 2. 初始化ADC:使用`ADC_Init()`函数初始化ADC外设。你可以设置转换分辨率、采样时间、触发模式等参数。 3. 配置ADC转换触发源(可选):如果你需要使用外部触发源来启动ADC转换,则需要配置触发源。你可以使用`ADC_ExternalTrigConvCmd()`函数启用或禁用外部触发。 4. 启动ADC转换:使用`ADC_Cmd()`函数启动ADC转换。 5. 等待转换完成:使用`ADC_GetFlagStatus()`函数或中断来检查转换完成标志位。如果使用中断,你可以在中断处理程序中读取ADC值。 6. 读取转换结果:使用`ADC_GetConversionValue()`函数读取ADC转换结果。 下面是一个简单的例子,演示了如何使用STM32标准库读取ADC值: ```c #include "stm32f10x.h" void ADC_Configuration(void) { ADC_InitTypeDef ADC_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; // 配置引脚为模拟输入模式 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); // 初始化ADC1 ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfChannel = 1; ADC_Init(ADC1, &ADC_InitStructure); // 配置ADC1通道0为采样时间为55.5个周期 ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5); // 启动ADC1 ADC_Cmd(ADC1, ENABLE); } int main(void) { uint16_t adc_value; // 初始化ADC ADC_Configuration(); while (1) { // 启动ADC转换 ADC_SoftwareStartConvCmd(ADC1, ENABLE); // 等待转换完成 while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); // 读取转换结果 adc_value = ADC_GetConversionValue(ADC1); // 处理ADC值 // ... // 延时一段时间 for (int i = 0; i < 100000; i++); } } ``` 这只是一个简单的示例,你可以根据自己的需求进行更复杂的配置和处理。请确保根据你所使用的具体芯片型号和库版本进行适当的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小土嘿嘿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值