標(biāo)題:
GP2Y1014AU這個傳感器有人使用過嗎?用stm32調(diào)試程序發(fā)現(xiàn)值不對
[打印本頁]
作者:
xda
時間:
2020-3-25 00:13
標(biāo)題:
GP2Y1014AU這個傳感器有人使用過嗎?用stm32調(diào)試程序發(fā)現(xiàn)值不對
本帖最后由 xda 于 2020-3-26 22:44 編輯
手頭有一個GP2Y1014AU傳感器,測量pm2.5的,心血來潮,想驅(qū)動玩一下,就自己焊接了個轉(zhuǎn)接板,調(diào)試了一下,發(fā)現(xiàn)有值
但是值并不正確。你問我怎么知道的。。。因為我拿香煙熏,但是傳感器值一點都不變化。。。。用香煙熏,adc數(shù)值我想怎么著都得到個幾大千吧。。。
然后翻遍百度,看到有一篇搜狐的文章說vo的典型值(沒有灰塵的情況下)是0.9v,然后回來打我這里的vo才幾毫伏,那個寶賣家只給了一個電容(220uf 16v)一個電阻(150om),電容我連接的是s-gnd和v—led,電阻連接5v和vled,vo連接A6,LED端連接的是A7,我想硬件應(yīng)該沒錯吧,一般來說stm32f103應(yīng)該是可以驅(qū)動這個led端的吧。。。。
以下附上代碼,代碼很簡單,只是我想在還沒有想明白我的問題到底處在了哪里.....
#include "adc.h"
#include "delay.h"
//初始化ADC
//這里我們僅以規(guī)則通道為例
//我們默認(rèn)將開啟通道0~3
void Adc_Init(void)
{
ADC_InitTypeDef ADC_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_ADC1 , ENABLE ); //使能ADC1通道時鐘
RCC_ADCCLKConfig(RCC_PCLK2_Div6); //設(shè)置ADC分頻因子6 72M/6=12,ADC最大時間不能超過14M
//PA1 作為模擬通道輸入引腳
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; //模擬輸入引腳
GPIO_Init(GPIOA, &GPIO_InitStructure);
//PB1 作為脈沖輸出引腳
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructure);
GP2Y_High;
ADC_DeInit(ADC1); //復(fù)位ADC1,將外設(shè) ADC1 的全部寄存器重設(shè)為缺省值
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC工作模式:ADC1和ADC2工作在獨(dú)立模式
ADC_InitStructure.ADC_ScanConvMode = DISABLE; //模數(shù)轉(zhuǎn)換工作在單通道模式
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; //模數(shù)轉(zhuǎn)換工作在單次轉(zhuǎn)換模式
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; //轉(zhuǎn)換由軟件而不是外部觸發(fā)啟動
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; //ADC數(shù)據(jù)右對齊
ADC_InitStructure.ADC_NbrOfChannel = 1; //順序進(jìn)行規(guī)則轉(zhuǎn)換的ADC通道的數(shù)目
ADC_Init(ADC1, &ADC_InitStructure); //根據(jù)ADC_InitStruct中指定的參數(shù)初始化外設(shè)ADCx的寄存器
ADC_Cmd(ADC1, ENABLE); //使能指定的ADC1
ADC_ResetCalibration(ADC1); //使能復(fù)位校準(zhǔn)
while(ADC_GetResetCalibrationStatus(ADC1)); //等待復(fù)位校準(zhǔn)結(jié)束
ADC_StartCalibration(ADC1); //開啟AD校準(zhǔn)
while(ADC_GetCalibrationStatus(ADC1)); //等待校準(zhǔn)結(jié)束
// ADC_SoftwareStartConvCmd(ADC1, ENABLE); //使能指定的ADC1的軟件轉(zhuǎn)換啟動功能
}
//獲得ADC值
//ch:通道值 0~3
u16 Get_Adc(u8 ch)
{
//設(shè)置指定ADC的規(guī)則組通道,一個序列,采樣時間
ADC_RegularChannelConfig(ADC1, ch, 0, ADC_SampleTime_239Cycles5 ); //ADC1,ADC通道,采樣時間為239.5周期
ADC_SoftwareStartConvCmd(ADC1, ENABLE); //使能指定的ADC1的軟件轉(zhuǎn)換啟動功能
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待轉(zhuǎn)換結(jié)束
return ADC_GetConversionValue(ADC1); //返回最近一次ADC1規(guī)則組的轉(zhuǎn)換結(jié)果
}
float GetGP2Y(void)
{
u32 AD_PM;
double pm;
GP2Y_Low;
delay_us(280);
AD_PM = Get_Adc(ADC_Channel_0); //PA0
delay_us(40);
GP2Y_High;
delay_us(9680);
pm = 0.17*AD_PM-0.1; //轉(zhuǎn)換公式
printf("%f\n",pm);
return pm;
}
u16 Get_GP2Y_Average(u8 times)
{
u32 pm_val=0;
u8 t;
for(t=0;t<times;t++)
{
pm_val+=GetGP2Y();
delay_ms(5);
}
return pm_val/times;
}
這是別人的代碼,順便問一下,這段初始化沒問題吧,這段代碼里面開啟adc1的時鐘是不是相當(dāng)于初始化了gpiob的時鐘?我的代碼就初始化和這里不一樣,其他原理都是差不多的,入門不久還是沒得到stm32的精髓
作者:
xda
時間:
2020-3-26 00:24
憋沉哇,鐵子
作者:
你若懂我
時間:
2020-4-7 15:12
加油,我挺你
作者:
Lucas-
時間:
2020-4-20 15:25
奇怪,為啥你的電容要這樣接呢,電容不應(yīng)該接到v-led和led-gnd之間嗎
作者:
daocheng
時間:
2020-4-26 14:32
是不是定時的問題啊,數(shù)據(jù)讀的不對?
沒用過啊,不過為你加油!再仔細(xì)檢查檢查程序,祝你早日成功!
作者:
cheerup1006
時間:
2020-7-10 10:36
硬件接的不對吧,硬件VO接的是A6,程序是A0腳;LED接的是A7,程序是B1腳
作者:
18012305
時間:
2023-4-6 22:54
我的也是電壓輸出0.0幾。在懷疑硬件電阻電容接錯或者就是短路了
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1