9种简单的数字滤波算法(C语言源程序)

时间:2012-05-12 10:22:38

[导读]假定从8位AD中读取数据(如果是更高位的AD可定义数据类型为int),子程序为get_ad();

1、限副滤波

/* A值可根据实际情况调整

value为有效值,new_value为当前采样值

滤波程序返回有效的实际值 *

假定从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

{

value_buf[count] = get_ad();

delay();

}

for (j=0;j

{

for (i=0;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

{

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

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

{

value_buf[count] = get_ad();

delay();

}

for (j=0;j

{

for (i=0;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

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

{

value_buf[count] = get_ad();

delay();

}

for (count=0,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;

}

来源:

作者:Juventus9554

换一批

延伸阅读

C语言一般提供三种预处理功能:宏处理、文件包含、条件编译。头文件防卫式申明中会用到条件编译中 #ifndef、#define、#endif 的用法。所以,首先价绍下条件编译。

1 条件编译

一般情况...

来源:https://segmentfault.com/a/1190000038292644

前言

我们经常会讨论这样的问题:什么时...

作者:被遗忘的博客 原文:https://www.cnblogs.com/rollenholt/archive/2012/03/20/2409046.html...

分享嘉宾:彭克炼 贝壳 资深工程师

编辑整理:马瑶

出品平台:DataFunTalk

导读:随着贝壳流量的日渐增长,贝壳商业化细分场景越来越丰富,公司对业务迭代和效果优化的效率有了更高的要求,贝壳商业化策略...

全局变量

作为一个嵌入式工程师

肯定有前人提示过你不要滥用

就在之前丰田公司就出过这么一档子事儿...

#字符串倒序输出

实现逻辑,通过strlen获取字符串长度,然后通过 len/2 进行交叉赋值,这里需要注意,不需要考虑len是奇数还是偶数的问题。

如果len是奇数,最后一个字符就不需要倒序,如果是偶数...

#字符串倒序输出

实现逻辑,通过strlen获取字符串长度,然后通过 len/2 进行交叉赋值,这里需要注意,不需要考虑len是奇数还是偶数的问题。

如果len是奇数,最后一个字符就不需要倒序,如果是偶数...

我想通过这篇短文向你展示C伟大的一面。

作者 | Jakub Lukasiewicz,已获作者翻译授权 出品 | CSDN(ID:CSDNnews) “第一门编程语言学C靠谱吗?” “我应该考虑学C吗?”...

关注+星标公众号,不错过精彩内容

作者 | Lucas

编排 | strongerHuang

本文由作者『Luca...

编排 | strongerHuang

微信公众号 | 嵌入式专栏

今天主要总结下常用的对称性加密算法DES和AES,非对称性加密算法RSA。...

滑动平均滤波c语言_9种简单的数字滤波算法(C语言源程序)相关推荐

  1. 滑动平均滤波c语言_10种简单的数字滤波算法(C语言源程序)

    假定从 8 位 AD 中读取数据(如果是更高位的 AD 可定义数据类型为 int ) , 子程序为 get_ad(); 1 .限副滤波 /* A 值可根据实际情况调整 value 为有效值, new_ ...

  2. c语言均值滤波程序,10种简单的数字滤波算法(C语言源程序)

    贴一个我的代码给大家 电路有市电 过零点检测 每次过零 启动150us的 TIMER1_ISR 中断 在3750 us开始,每隔150us采集一次市电的 ADC 以检测用的市电是110v还是220V ...

  3. 滑动平均滤波c语言_11种经典软件滤波算法及其波形效果图(附C语言程序)

    (后页附带C语言程序) 注意注意注意:(图像中红线都是经过滤波的)1.限幅滤波法(又称程序判断滤波法) A.方法: 根据经验判断,确定两次采样允许的最大偏差值(设为 A) 每次检测到新值时判断: 如果 ...

  4. C语言实现的滑动平均滤波算法

    最近采集压力传感器的电压信号,采集到的数据波动挺大的,所以采用滤波的方法进行处理一下. 因为在matlab中依靠matlab的画图函数很容易看到滤波后的数据图像,进而验证滤波效果. 所以首先将采集到的 ...

  5. 滑动平均滤波c语言_常用滤波算法及C语言程序实现

    1.限幅滤波法(又称程序判断滤波法) A.方法: 根据经验判断,确定两次采样允许的最大偏差值(设为A) 每次检测到新值时判断: 如果本次值与上次值之差<=A,则本次值有效 如果本次值与上次值之差 ...

  6. 滑动平均滤波_11种滤波算法程序大全(含源代码分享)

    1.限幅滤波法(又称程序判断滤波法) /*A.名称:限幅滤波法(又称程序判断滤波法)B.方法: 根据经验判断,确定两次采样允许的最大偏差值(设为A), 每次检测到新值时判断: 如果本次值与上次值之差& ...

  7. C 语言实现的滑动平均滤波算法,滑动平均滤波算法(递推平均滤波法)

    /// ///滑动平均滤波算法(递推平均滤波法) /// /// /// GN为数组value_buf[]的元素个数,该函数主要被调用,利用参数的数组传值 /// private const int ...

  8. C语言 实时滑动平均滤波 动态改变滑动框内元素数目

    #直接上代码 #include <stdio.h> #include <malloc.h> typedef unsigned int uint32_t;//uint32_t _ ...

  9. π型滤波频率计算_滑动平均滤波的截止频率与平均点数计算

    1.介绍 滑动平均值滤波可以去除随机噪声.测量中随机噪声的影响,使测量结果不准确,通过多次测量同一数据源,使用多点集合平均的方法得到数据一个比较合理的估计就是滑动平均值滤波. 例如第80采样点的5次平 ...

  10. python 曲线平滑处理——方法总结(Savitzky-Golay 滤波器、make_interp_spline插值法和convolve滑动平均滤波)

    文章目录 1 插值法对曲线平滑处理 1.1 插值法的常见实现方法 1.2 拟合和插值的区别 1.3 代码实例 2 Savitzky-Golay 滤波器实现曲线平滑 2.1 问题描述 2.2 Savit ...

最新文章

  1. 贝叶斯推断及其互联网应用(二):过滤垃圾邮件
  2. 波形捕捉:(1)枚举捕捉设备
  3. Go语言defer详解
  4. opencv用java完成的例子_SpringBoot整合OpenCV的实现示例
  5. This EntitySet of type xxx does not support the 'Edit' operation
  6. asp.net ajax技巧6
  7. 企业数字化新战场:低代码究竟是“毒瘤”还是“良药”?
  8. STM32之SDIO原理
  9. 小程序已成BAT争锋新战场
  10. 解决Win10中WerFault错误报告问题
  11. 微型计算机及原理怎么进制的,微型计算机原理及应用课件bcd码运算肥的十进制.ppt...
  12. 2.13.PHP7.1 狐教程-【PHP 类】
  13. [C#] LINQ之GroupBy
  14. Linux内核系统调用原理与实现
  15. 串口连接交换机,进行交互
  16. 【Python】简单判定身份证是否合法、性别
  17. 闭关修炼(十二) NIO
  18. 盘点16种常见的PCB可靠性测试,您的板经得起测试吗?
  19. 在Word和OneNote中插入数学公式
  20. 全球最大同性交友网站的所有用户密码都无法登录!!!

热门文章

  1. 51单片机—红外遥控
  2. pic由c语言和汇编语言,单片机教程:PIC单片机C语言程序设计(二)
  3. 操作系统原理1-3章答案 黑新宏 胡元义主编
  4. spoonwep下载地址
  5. 1. 并行与分布式系统简介
  6. java并发编程入门_Java并发编程从入门到精通 PDF 下载
  7. OpenGL 中的 Render To Texture
  8. jpg格式电脑怎么弄_电脑上图片改为jpg格式方法_照片怎么改为jpg格式-win7之家
  9. 黑客工具软件大全100套(转)
  10. Linux僵尸进程怎么处理,Linux 僵尸进程如何处理