標(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)沒起到作用,高手幫忙看看問題出在哪。

正常程序:
  1. //ADC電阻換算公式:
  2. uint ADC_R(uchar dat)
  3. {
  4.         uint teme;
  5.         ADC_Read(dat);                 //丟掉兩次檢測(cè)
  6.         ADC_Read(dat);
  7.         VADC=ADC_Read(dat);            //讀取第x通道ADC結(jié)果
  8.         teme=(VCC-VCC*(ulong)VADC/4096)/((1.0)*VCC*(ulong)VADC/4096/VCR)-3;//3為限流電阻
  9.         return teme;
  10. }
復(fù)制代碼

更改后的濾波寫法:
  1. #define N 8    //ADC采樣使用遞推平均濾波算法,采樣次數(shù)
  2. unsigned int ADC_Buf[N+1];        //采樣數(shù)組阻值
  3. unsigned int current=0;            //采樣阻值
  4. unsigned char num,ADCcount=0,ADCcount2=0;    //ADC采樣次數(shù)變量

  5. //ADC電阻換算公式:
  6. uint ADC_R(uchar dat)
  7. {
  8.         unsigned char xx;
  9.   unsigned int sum,currentvalue;
  10.         uint teme;
  11.         ADC_Read(dat);                 //丟掉兩次檢測(cè)
  12.         ADC_Read(dat);
  13.         VADC=ADC_Read(dat);            //讀取第x通道ADC結(jié)果
  14.   sum = currentvalue =0;   
  15.   ADC_Buf[N]=ADC_Read(2);       //將ADC轉(zhuǎn)換結(jié)果放數(shù)組最高位
  16.   if( ++ADCcount < 8)        //采樣初期不使用濾波算法
  17.     {   
  18.     for(xx=0;xx<N;xx++)    //準(zhǔn)備濾波算法的數(shù)據(jù)
  19.     {
  20.     ADC_Buf[xx]=ADC_Buf[xx+1];//所有數(shù)據(jù)循環(huán)左移
  21.     }
  22.     currentvalue=ADC_Buf[N];//采樣初期使用當(dāng)前采樣值
  23.     }
  24.     else     //只有采樣次數(shù)大于8次以后才使用濾波算法   
  25.     {
  26.     ADCcount=8;    //采樣次數(shù)超過8次后,固定設(shè)置為8
  27.     for(xx=0;xx<N;xx++)    //濾波算法
  28.     {
  29.     ADC_Buf[xx]=ADC_Buf[xx+1];//所有數(shù)據(jù)循環(huán)左移
  30.     sum+=ADC_Buf[xx];    //求和
  31.     }
  32.     currentvalue=sum/N;        //求平均值        
  33.     }   
  34.     teme=currentvalue;
  35.           teme=(VCC-VCC*(ulong)VADC/4096)/((1.0)*VCC*(ulong)VADC/4096/VCR)-3;//3為限流電阻
  36.           return teme;
  37. }
復(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