ADC簡介
-
ADC簡介
-
- ADC(Analog-Digital Converter)模擬-數(shù)字轉換器
-
- ADC可以將引腳上連續(xù)變化的模擬電壓轉換為內存中存儲的數(shù)字變量,建立模擬電路到數(shù)字電路的橋梁
-
- 12位逐次逼近型ADC,1us轉換時間
-
- 輸入電壓范圍:0~ 3.3V,轉換結果范圍:0~ 4095
-
- 18個輸入通道,可測量16個外部和2個內部信號源
-
- 規(guī)則組和注入組兩個轉換單元
-
- 模擬看門狗自動監(jiān)測輸入電壓范圍
-
- STM32F103C8T6 ADC資源:ADC1、ADC2,10個外部輸入通道
DAC 數(shù)字變量轉化為模擬遍變量
AD單通道
第一步 開啟RCC時鐘 ,包括ADC和GPIO的時鐘 ADCCLK的分頻器也需要配置
第二步 配置GPIO把需要用的配置成模擬輸入的模式
第三步 配置多路開關把左邊的通道接入到右邊的規(guī)則組列表里
第四步 配置AD轉換器 {
單次轉換還是連續(xù)轉換
掃描還是非掃描
有幾個通道
觸發(fā)源是什么
數(shù)據對齊時左對齊還是右對齊
}
第五部開啟ADC
ADC配置函數(shù)
//ADCCLK分頻器配置
RCC_ADCCLKConfig 可以選擇2、4、6、8分頻輸入到ADCCLK
//恢復缺省配置
void ADC_DeInit(ADC_TypeDef* ADCx);
//Init初始化
void ADC_Init(ADC_TypeDef* ADCx, ADC_InitTypeDef* ADC_InitStruct);
//StructiInit 結構體初始化
void ADC_StructInit(ADC_InitTypeDef* ADC_InitStruct);
//ADC上電 開關控制
void ADC_Cmd(ADC_TypeDef* ADCx, FunctionalState NewState);
//用于開啟DMA輸出信號的
void ADC_DMACmd(ADC_TypeDef* ADCx, FunctionalState NewState);
//中斷輸出控制 用于控制某個中斷能否通往NVIC
void ADC_ITConfig(ADC_TypeDef* ADCx, uint16_t ADC_IT, FunctionalState NewState);
//復位校準
void ADC_ResetCalibration(ADC_TypeDef* ADCx);
//獲取復位校準狀態(tài)
FlagStatus ADC_GetResetCalibrationStatus(ADC_TypeDef* ADCx);
//開啟校準 ,獲取開始校準狀態(tài)
void ADC_StartCalibration(ADC_TypeDef* ADCx);
FlagStatus ADC_GetCalibrationStatus(ADC_TypeDef* ADCx);
// 用于軟件觸發(fā)的函數(shù)
void ADC_SoftwareStartConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
//判斷是否結束
FlagStatus ADC_GetFlagStatus(ADC_TypeDef* ADCx, uint8_t ADC_FLAG);
//配置間斷模式
void ADC_DiscModeChannelCountConfig(ADC_TypeDef* ADCx, uint8_t Number);
void ADC_DiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
//ADC規(guī)則組通道配置
void ADC_RegularChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);
//ADC外部觸發(fā)轉換控制 是否允許外部觸發(fā)轉換
void ADC_ExternalTrigConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
//ADC獲取轉換值
uint16_t ADC_GetConversionValue(ADC_TypeDef* ADCx);
//ADC獲取雙模式轉換值
uint32_t ADC_GetDualModeConversionValue(void);
初始化代碼編寫
第一步開啟時鐘
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
第二步 RCCCLK分頻 6分頻 72M/6=12M
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//72/6
第三步 配置GPIO 配置為AIN狀態(tài)
AIN狀態(tài)下GPIO時無效的 斷開GPIO,防止GPIO口的輸入輸出對我模擬電壓造成干擾,AIN模式 ADC的專屬模式
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;// input moni
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_Init(GPIOA, &GPIO_InitStructure);
第四步,選擇規(guī)則組的輸入通道
ADC_RegularChannelConfig(ADC1, ADC_Channel_0,1,ADC_SampleTime_55Cycles5);
第一個參數(shù) ADCx
第二個參數(shù) 通道0 ~ 17
第三個參數(shù) 規(guī)則組序列器里的次序 1 ~ 16
第四個參數(shù) 采樣時間 55.5 采樣時間55.5*ADCCLK的周期
第五步 用結構體 初始化ADC
ADC_InitTypeDef ADC_InitStruture;
//ADC的工作模式 獨立模式還是雙ADC模式
ADC_InitStruture.ADC_Mode=ADC_Mode_Independent;
//數(shù)據對齊
ADC_InitStruture.ADC_DataAlign=ADC_DataAlign_Right;
//外部觸發(fā)源選擇 軟件觸發(fā)
ADC_InitStruture.ADC_ExternalTrigConv=ADC)ExternalTrigConv_None;
//單詞轉換 非掃描
ADC_InitStruture.ADC_ContinuousConvMode= DISABLE;
ADC_InitStruture.ADC_ScanConvMode=DISABLE;
//通道數(shù)目
ADC_InitStruture.ADC_NbrOfChannel =1 ;
ADC_Cmd(ADC1,ENABLE);//啟動
第六步 對ADC進行校準
ADC_ResetCalibration(ADC1);//reset
while(ADC_GetResetCalibrationStatus(ADC1)==SET);//等待校準完成
ADC_StartCalibration(ADC1);
while(ADC_GetCalibrationStatus(ADC1)==SET);
編寫獲取電壓函數(shù)
uint16_t AD_GetValue(void){
ADC_SoftwareStartConvCmd(ADC1,ENABLE);//ruan jian chu fa
while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC)==RESET);
return ADC_GetConversionValue(ADC1);
}
這時候獲得的不是直觀電壓
我們需要線性變換
float V=(float)ADC_GetConversionValue(ADC1)/4095 *3.3
應用場景
結合光敏傳感器文章來源:http://www.zghlxwxcb.cn/news/detail-693397.html
當電壓低于某個閾值時關燈 ,高于某個閾值時開燈
但是電壓總是會抖動 ,如果是一個確定的閾值,那么有時候會出現(xiàn)亮滅抖動, 我們可以搞一個下界閾值,和上屆閾值,如果高于上屆閾值開燈
,而低于下屆閾值則關燈,上屆與下屆閾值之間又一定的差值,這個差值高于抖動區(qū)間,類似于施密特觸發(fā)器文章來源地址http://www.zghlxwxcb.cn/news/detail-693397.html
初始化代碼如下
#include "stm32f10x.h" // Device header
void AD_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_Mode_AIN;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5);
ADC_InitTypeDef ADC_InitStructure;
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_NbrOfChannel = 1;
ADC_Init(ADC1, &ADC_InitStructure);
ADC_Cmd(ADC1, ENABLE);
ADC_ResetCalibration(ADC1);
while (ADC_GetResetCalibrationSta tus(ADC1) == SET);
ADC_StartCalibration(ADC1);
while (ADC_GetCalibrationStatus(ADC1) == SET);
}
uint16_t AD_GetValue(void)
{
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET);
return ADC_GetConversionValue(ADC1);
}
Main函數(shù)編寫
#include "stm32f10x.h" // Device header
#include "Delay.h"
#include "OLED.h"
#include "AD.h"
uint16_t ADValue;
float Voltage;
int main(void)
{
OLED_Init();
AD_Init();
OLED_ShowString(1, 1, "ADValue:");
OLED_ShowString(2, 1, "Volatge:0.00V");
while (1)
{
ADValue = AD_GetValue();
Voltage = (float)ADValue / 4095 * 3.3;
OLED_ShowNum(1, 9, ADValue, 4);
OLED_ShowNum(2, 9, Voltage, 1);
OLED_ShowNum(2, 11, (uint16_t)(Voltage * 100) % 100, 2);
Delay_ms(100);
}
}
到了這里,關于STM32f103入門(10)ADC模數(shù)轉換器的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網!