《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 10種簡單的數字濾波算法
10種簡單的數字濾波算法
摘要: 本文詳細介紹了10種簡單的用C語言描述的數字濾波算法。
Abstract:
Key words :

  假定從8位AD中讀取數據(如果是更高位的AD可定義數據類型為int),子程序為get_ad();

  1、限副濾波

  /* A值可根據實際情況調整

  value為有效值,new_value為當前采樣值

  濾波程序返回有效的實際值 */

  #define A 10

  char value;

  char filter()

  {

  char new_value;

  new_value = get_ad();

  if ( ( new_value - value 》 A ) || ( value - new_value 》 A )

  return value;

  return new_value;

  }

  2、中位值濾波法

  /* N值可根據實際情況調整

  排序采用冒泡法*/

  #define N 11

  char filter()

  {

  char value_buf[N];

  char count,i,j,temp;

  for ( count=0;count《N;count++)

  {

  value_buf[count] = get_ad();

  delay();

  }

  for (j=0;j《N-1;j++)

  {

  for (i=0;i《N-j;i++)

  {

  if ( value_buf[i]》value_buf[i+1] )

  {

  temp = value_buf[i];

  value_buf[i] = value_buf[i+1];

  value_buf[i+1] = temp;

  }

  }

  }

  return value_buf[(N-1)/2];

  }

  3、算術平均濾波法

  /*

  */

  #define N 12

  char filter()

  {

  int sum = 0;

  for ( count=0;count《N;count++)

  {

  sum + = get_ad();

  delay();

  }

  return (char)(sum/N);

  }

  4、遞推平均濾波法(又稱滑動平均濾波法)

  /*

  */

  #define N 12

  char value_buf[N];

  char i=0;

  char filter()

  {

  char count;

  int sum=0;

  value_buf[i++] = get_ad();

  if ( i == N ) i = 0;

  for ( count=0;count《N,count++)

  sum = value_buf[count];

  return (char)(sum/N);

  }

  5、中位值平均濾波法(又稱防脈沖干擾平均濾波法)

  /*

  */

  #define N 12

  char filter()

  {

  char count,i,j;

  char value_buf[N];

  int sum=0;

  for (count=0;count《N;count++)

  {

  value_buf[count] = get_ad();

  delay();

  }

  for (j=0;j《N-1;j++)

  {

  for (i=0;i《N-j;i++)

  {

  if ( value_buf[i]》value_buf[i+1] )

  {

  temp = value_buf[i];

  value_buf[i] = value_buf[i+1];

  value_buf[i+1] = temp;

  }

  }

  }

  for(count=1;count《N-1;count++)

  sum += value[count];

  return (char)(sum/(N-2));

  }

  假定從8位AD中讀取數據(如果是更高位的AD可定義數據類型為int),子程序為get_ad();

  1、限副濾波

  /* A值可根據實際情況調整

  value為有效值,new_value為當前采樣值

  濾波程序返回有效的實際值 */

  #define A 10

  char value;

  char filter()

  {

  char new_value;

  new_value = get_ad();

  if ( ( new_value - value 》 A ) || ( value - new_value 》 A )

  return value;

  return new_value;

  }

  2、中位值濾波法

  /* N值可根據實際情況調整

  排序采用冒泡法*/

  #define N 11

  char filter()

  {

  char value_buf[N];

  char count,i,j,temp;

  for ( count=0;count《N;count++)

  {

  value_buf[count] = get_ad();

  delay();

  }

  for (j=0;j《N-1;j++)

  {

  for (i=0;i《N-j;i++)

  {

  if ( value_buf[i]》value_buf[i+1] )

  {

  temp = value_buf[i];

  value_buf[i] = value_buf[i+1];

  value_buf[i+1] = temp;

  }

  }

  }

  return value_buf[(N-1)/2];

  }

  3、算術平均濾波法

  /*

  */

  #define N 12

  char filter()

  {

  int sum = 0;

  for ( count=0;count《N;count++)

  {

  sum + = get_ad();

  delay();

  }

  return (char)(sum/N);

  }

  4、遞推平均濾波法(又稱滑動平均濾波法)

  /*

  */

  #define N 12

  char value_buf[N];

  char i=0;

  char filter()

  {

  char count;

  int sum=0;

  value_buf[i++] = get_ad();

  if ( i == N ) i = 0;

  for ( count=0;count《N,count++)

  sum = value_buf[count];

  return (char)(sum/N);

  }

  5、中位值平均濾波法(又稱防脈沖干擾平均濾波法)

  /*

  */

  #define N 12

  char filter()

  {

  char count,i,j;

  char value_buf[N];

  int sum=0;

  for (count=0;count《N;count++)

  {

  value_buf[count] = get_ad();

  delay();

  }

  for (j=0;j《N-1;j++)

  {

  for (i=0;i《N-j;i++)

  {

  if ( value_buf[i]》value_buf[i+1] )

  {

  temp = value_buf[i];

  value_buf[i] = value_buf[i+1];

  value_buf[i+1] = temp;

  }

  }

  }

  for(count=1;count《N-1;count++)

  sum += value[count];

  return (char)(sum/(N-2));

  }

  6、限幅平均濾波法

  /*

  */

  略 參考子程序1、3

  7、一階滯后濾波法

  /* 為加快程序處理速度假定基數為100,a=0~100 */

  #define a 50

  char value;

  char filter()

  {

  char new_value;

  new_value = get_ad();

  return (100-a)*value + a*new_value;

  }

  8、加權遞推平均濾波法

  /* coe數組為加權系數表,存在程序存儲區。*/

  #define N 12

  char code coe[N] = {1,2,3,4,5,6,7,8,9,10,11,12};

  char code sum_coe = 1+2+3+4+5+6+7+8+9+10+11+12;

  char filter()

  {

  char count;

  char value_buf[N];

  int sum=0;

  for (count=0,count《N;count++)

  {

  value_buf[count] = get_ad();

  delay();

  }

  for (count=0,count《N;count++)

  sum += value_buf[count]*coe[count];

  return (char)(sum/sum_coe);

  }

  9、消抖濾波法

  #define N 12

  char filter()

  {

  char count=0;

  char new_value;

  new_value = get_ad();

  while (value !=new_value);

  {

  count++;

  if (count》=N) return new_value;

  delay();

  new_value = get_ad();

  }

  return value;

  }

  10、限幅消抖濾波法

  /*

  */

  略 參考子程序1、9

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 欧美日本在线三级视频| 亚洲国产日产无码精品| 亚洲小说区图片区另类春色| 久碰人澡人澡人澡人澡人视频| 中文字幕成人乱码在线电影| 99久久免费国产精品| 香港全黄一级毛片在线播放| 男人日女人app| 日韩欧美在线看| 好男人www社区| 国产福利久久青青草原下载| 午夜亚洲av日韩av无码大全| 亚洲人成精品久久久久| 一本大道加勒比久久综合| 日韩视频第二页| 第九色区AV天堂| 日本理论片午夜论片 | 师尊要被cao坏了by谦野| 国产激情一区二区三区四区| 免费萌白酱国产一区二区| 久久精品无码一区二区三区| 97久久久久人妻精品专区| 天天影院成人免费观看| 黄色网站在线免费观看| 精品久久人妻av中文字幕| 日韩精品久久久肉伦网站| 国语自产精品视频在线区| 国产一区三区二区中文在线| 亚洲欧美中文日韩在线| 一级做a爰片性色毛片视频图片| 黑人啊灬啊灬啊灬快灬深| 欧美综合自拍亚洲综合图| 思思久久99热只有精品| 国产午夜鲁丝片av无码免费| 亚洲国产成人精品久久| av网站免费线看| 精品爆乳一区二区三区无码av| tube6xxxxxhd丶中国| 91福利精品老师国产自产在线| 美女扒开胸罩让男生吃乳| 日韩欧美国产三级|