久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

ADC中值平均濾波得到的值不正確。

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:705846 發(fā)表于 2024-12-16 19:22 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
代碼采用ADC中斷式, ,ADC值抖動的更厲害了,請高手幫忙檢查一下代碼是否有問題。謝謝大家。

  1. #define        N        12        //取中值
  2. typedef unsigned char BYTE;
  3. typedef unsigned int WORD;

  4. WORD ADCx,ADCbg,bandgap,ADCx10filter,ADCx11filter;
  5. WORD VoltageBuf[N],CurrentBuf[N];


  6. // 初始化ADC
  7. void InitADC() {
  8.     P1ASF = 0x03;// (1 << ADC_CHANNEL); // 設(shè)置P1.0,P1.1為ADC輸入
  9.     ADC_RES = 0;ADC_RESL = 0; // 清除ADC結(jié)果寄存器
  10.                 CLK_DIV = 0x20;
  11.     ADC_CONTR = 0x88|0x01;//ADC_POWER | ADC_SPEEDLL | ADC_CHANNEL; // 使能ADC,設(shè)置速度為最快
  12.     Delay20ms(); // 等待ADC穩(wěn)定
  13.     EADC = 1;
  14. }


  15. //中值濾波法(去掉最大,最小值,取平均值)
  16. void filter(char channel)
  17. {
  18.                 char i,j,count;
  19.                 int crtemp,votemp,sum=0;
  20.                 if(channel==0){
  21.                                 for(j=0;j<(N-1);j++)
  22.                                         {
  23.                                                 for(i=0;i<(N-j);i++)
  24.                                                 {        
  25.                                                                  if(CurrentBuf[i]>CurrentBuf[i+1])
  26.                                                                         {
  27.                                                                                 crtemp = CurrentBuf[i];
  28.                                                                                 CurrentBuf[i]= CurrentBuf[i+1];
  29.                                                                                 CurrentBuf[i+1]= crtemp;
  30.                                                                         }
  31.                                                 }
  32.                                         }
  33.                         for(count =1;count<N-1;count++)        sum += CurrentBuf[count];
  34.                         ADCx10filter=sum/(N-2);                                       
  35.                 }
  36.                         
  37.                         if(channel==1){
  38.                                 for(j=0;j<(N-1);j++)
  39.                                         {
  40.                                                 for(i=0;i<(N-j);i++)
  41.                                                 {        
  42.                                                                  if(VoltageBuf[i]>VoltageBuf[i+1])
  43.                                                                         {
  44.                                                                                 votemp = VoltageBuf[i];
  45.                                                                                 VoltageBuf[i] = VoltageBuf[i+1];
  46.                                                                                 VoltageBuf[i+1] = votemp;
  47.                                                                         }
  48.                                                 }
  49.                                         }
  50.                         for(count =1;count<N-1;count++)        sum += VoltageBuf[count];
  51.                         ADCx11filter=sum/(N-2);                                       
  52.                         }

  53. }

  54. //ADC中斷函數(shù)
  55. void adc_isr()interrupt 5 using 1
  56. {
  57.         static char vo=0,cr=0,ch=0;
  58.         //        ADC_CONTR &= !0x10; //CLOSE ADC ADC_FLAG復(fù)位
  59.                 ADC_CONTR &= ~ADC_FLAG;
  60.                 if(ch==0)        
  61.                         {        
  62.                                 CurrentBuf[cr] = (ADC_RES*256+ADC_RESL);
  63.                                 cr++;
  64.                                 if(cr==N){
  65.                                         cr=0;
  66.                                         filter(0);
  67.                                 }
  68.                         }
  69.                 if(ch==1)
  70.                 {
  71.                                 VoltageBuf[vo] = (ADC_RES*256+ADC_RESL);
  72.                                 vo++;
  73.                                 if(vo==N){
  74.                                         vo=0;
  75.                                         filter(1);
  76.                                 }
  77.                 }

  78.                 ch++;
  79.                 if(ch>1)ch=0;
  80.                 ADC_CONTR = 0x88|ch; //ADC_POWER | ADC_SPEEDLL | 0x02 | ADC_START;
  81. }
復(fù)制代碼
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:621776 發(fā)表于 2024-12-17 10:08 | 只看該作者
我簡單看下你好像用的是均值濾波,直接排序后取中值是不是容易許多?
void array_sort(uint32_t* arr, uint8_t len) {
        uint8_t i, j, k;
        uint32_t temp = 0;
        for (i = 0; i < len - 1; i++) {
                k = i;
                for (j = i + 1; j < len; j++) {
                        if (arr[k] > arr[j]) {
                                k = j;
                        }
                }
                if (k != i) {
                        temp = arr[k];
                        arr[k] = arr[i];
                        arr[i] = temp;
                }
        }
}
假設(shè)調(diào)用函數(shù)是是buf[11],那么使用函數(shù)array_sort(&buf,11); 之后buf[5]就是中值
回復(fù)

使用道具 舉報

板凳
ID:1133081 發(fā)表于 2024-12-17 13:43 | 只看該作者
這代碼出現(xiàn)ADC值不穩(wěn)定的主要原因不在于采用了什么濾波方式,而是不合理的使用ADC中斷及中斷函數(shù)代碼。ADC中斷函數(shù)不斷在兩個通道之間切換。看代碼應(yīng)該是使用的STC系列1T單片機(jī),由于ADC轉(zhuǎn)換速度非常快,那么ADC中斷周期必然很短。如此快速切換通道,ADC模塊內(nèi)濾波電容來不及充放電,造成取樣不準(zhǔn)。獲取的ADC結(jié)果更新速度又遠(yuǎn)大于數(shù)據(jù)處理速度(濾波函數(shù)運(yùn)行一次的過程中ADC中斷可能已運(yùn)行多次)。最終的結(jié)果必然不穩(wěn)定。需要設(shè)置一個標(biāo)志,在數(shù)據(jù)處理完成后才允許執(zhí)行下一次ADC采樣。
回復(fù)

使用道具 舉報

地板
ID:705846 發(fā)表于 2024-12-17 20:07 | 只看該作者
T0m 發(fā)表于 2024-12-17 10:08
我簡單看下你好像用的是均值濾波,直接排序后取中值是不是容易許多?
void array_sort(uint32_t* arr, uin ...

用了過濾器后抖動的更厲害了。調(diào)低了ADC的采樣速度才有改善。謝謝大家回顧。
回復(fù)

使用道具 舉報

5#
ID:1140234 發(fā)表于 2024-12-18 00:20 | 只看該作者
可能是因為中斷服務(wù)例程中的處理時間過長,導(dǎo)致ADC采樣不連續(xù)或者錯過了一些樣本。可以嘗試減少中斷服務(wù)例程中的處理時間,只存儲ADC值,然后在主循環(huán)中進(jìn)行濾波處理。
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲国产成人精品一区二区 | 天天干狠狠操 | 久久久精品网站 | 中文字字幕在线中文乱码范文 | 日日操夜夜操天天操 | 一区二区福利视频 | 欧美福利 | 自拍视频国产 | 国产福利在线播放 | 精品中文字幕一区二区三区 | 国精产品一区一区三区免费完 | 中文字幕精品一区 | 91视视频在线观看入口直接观看 | 在线观看视频一区 | 亚洲三区视频 | 天堂色| 成人国内精品久久久久一区 | av中文字幕网站 | 人人干人人干人人 | 日本理论片好看理论片 | 欧美精品福利 | 区一区二区三在线观看 | 人成久久 | 免费在线a视频 | 亚洲精品久久久蜜桃网站 | 国产一区二区观看 | 福利精品在线观看 | 日韩欧美国产精品 | 亚洲成人在线视频播放 | 欧美日韩午夜精品 | 久久国内精品 | 91大神在线资源观看无广告 | 欧洲精品一区 | 国产激情 | 自拍偷拍中文字幕 | 亚洲综合色视频在线观看 | 国产日韩一区二区 | 亚洲一区二区视频在线观看 | 欧美三区视频 | 精品国产乱码久久久久久丨区2区 | 国产一二三区免费视频 |