標(biāo)題:
單片機(jī)軟件濾波不起作用,錯(cuò)在哪了
[打印本頁]
作者:
jony1122
時(shí)間:
2024-6-24 20:04
標(biāo)題:
單片機(jī)軟件濾波不起作用,錯(cuò)在哪了
單片機(jī)STC8H8K64U,測(cè)電阻程序。
可以正常測(cè)試并顯示阻值數(shù),只是數(shù)據(jù)有些跳動(dòng),在本論壇找了個(gè)軟件濾波的范例,求平均值,但是發(fā)現(xiàn)沒起到作用,高手幫忙看看問題出在哪。
正常程序:
//ADC電阻換算公式:
uint ADC_R(uchar dat)
{
uint teme;
ADC_Read(dat); //丟掉兩次檢測(cè)
ADC_Read(dat);
VADC=ADC_Read(dat); //讀取第x通道ADC結(jié)果
teme=(VCC-VCC*(ulong)VADC/4096)/((1.0)*VCC*(ulong)VADC/4096/VCR)-3;//3為限流電阻
return teme;
}
復(fù)制代碼
更改后的濾波寫法:
#define N 8 //ADC采樣使用遞推平均濾波算法,采樣次數(shù)
unsigned int ADC_Buf[N+1]; //采樣數(shù)組阻值
unsigned int current=0; //采樣阻值
unsigned char num,ADCcount=0,ADCcount2=0; //ADC采樣次數(shù)變量
//ADC電阻換算公式:
uint ADC_R(uchar dat)
{
unsigned char xx;
unsigned int sum,currentvalue;
uint teme;
ADC_Read(dat); //丟掉兩次檢測(cè)
ADC_Read(dat);
VADC=ADC_Read(dat); //讀取第x通道ADC結(jié)果
sum = currentvalue =0;
ADC_Buf[N]=ADC_Read(2); //將ADC轉(zhuǎn)換結(jié)果放數(shù)組最高位
if( ++ADCcount < 8) //采樣初期不使用濾波算法
{
for(xx=0;xx<N;xx++) //準(zhǔn)備濾波算法的數(shù)據(jù)
{
ADC_Buf[xx]=ADC_Buf[xx+1];//所有數(shù)據(jù)循環(huán)左移
}
currentvalue=ADC_Buf[N];//采樣初期使用當(dāng)前采樣值
}
else //只有采樣次數(shù)大于8次以后才使用濾波算法
{
ADCcount=8; //采樣次數(shù)超過8次后,固定設(shè)置為8
for(xx=0;xx<N;xx++) //濾波算法
{
ADC_Buf[xx]=ADC_Buf[xx+1];//所有數(shù)據(jù)循環(huán)左移
sum+=ADC_Buf[xx]; //求和
}
currentvalue=sum/N; //求平均值
}
teme=currentvalue;
teme=(VCC-VCC*(ulong)VADC/4096)/((1.0)*VCC*(ulong)VADC/4096/VCR)-3;//3為限流電阻
return teme;
}
復(fù)制代碼
數(shù)碼管顯示的電阻值為269.3 K、270.3K、271.3K、272K。
用萬用表顯示阻值為269K
想求電阻值的平均值,或電阻值的最小值,以減少阻值數(shù)據(jù)的跳動(dòng)。
濾波程序錯(cuò)在哪了。
感謝!
作者:
lkc8210
時(shí)間:
2024-6-24 23:31
16行為什么是ADC_Buf[N]=ADC_Read(2); ?
作者:
ly1972001
時(shí)間:
2024-6-25 08:49
網(wǎng)上找濾波程序啊。簡(jiǎn)單點(diǎn)就是,采樣一批數(shù)據(jù),求平均。
作者:
LaoYuTou
時(shí)間:
2024-6-25 09:10
36行,你用teme做了平均,但是你用VADC做的運(yùn)算,沒有使用起到濾波作用teme。
作者:
炸掉的電容
時(shí)間:
2024-6-25 11:59
采集電壓很快的,你采集十次電壓,去掉一個(gè)最高一個(gè)最低,八個(gè)取平均
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1