找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1173|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

單片機(jī)軟件濾波不起作用,錯在哪了

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:1045846 發(fā)表于 2024-6-24 20:04 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
單片機(jī)STC8H8K64U,測電阻程序。
可以正常測試并顯示阻值數(shù),只是數(shù)據(jù)有些跳動,在本論壇找了個軟件濾波的范例,求平均值,但是發(fā)現(xiàn)沒起到作用,高手幫忙看看問題出在哪。

正常程序:
  1. //ADC電阻換算公式:
  2. uint ADC_R(uchar dat)
  3. {
  4.         uint teme;
  5.         ADC_Read(dat);                 //丟掉兩次檢測
  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);                 //丟掉兩次檢測
  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ù)的跳動。
濾波程序錯在哪了。
感謝!
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:161164 發(fā)表于 2024-6-24 23:31 | 只看該作者
16行為什么是ADC_Buf[N]=ADC_Read(2); ?
回復(fù)

使用道具 舉報

板凳
ID:236035 發(fā)表于 2024-6-25 08:49 | 只看該作者
網(wǎng)上找濾波程序啊。簡單點就是,采樣一批數(shù)據(jù),求平均。
回復(fù)

使用道具 舉報

地板
ID:1080935 發(fā)表于 2024-6-25 09:10 | 只看該作者
36行,你用teme做了平均,但是你用VADC做的運算,沒有使用起到濾波作用teme。
回復(fù)

使用道具 舉報

5#
ID:925236 發(fā)表于 2024-6-25 11:59 | 只看該作者
采集電壓很快的,你采集十次電壓,去掉一個最高一個最低,八個取平均
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表