滤波器实验报告.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
滤波器实验报告.doc

数据处理算法实验报告 实验的目的: 熟悉掌握子程序、数组等C语言结构的使用方法。 熟悉各种数据处理办法。 实验用设备: PC系列微型计算机,操作系统使用DOS或Windows98。 实验要求: 完成如下数据处理算法,形成相应功能的函数: 算数平均值法 中位值算法 去掉极值的算数平均值算法 滑动平均滤波算法 加权平均滤波算法 数字低通滤波器 具有快速响应的数字滤波器 设计和计算: 从一文本中获取数据,并储存到数组中,传递给不同过程进行数据处理; 分别用不同的此程序实现不同的算法,并输出数据 2.1算数平均值法:【 void sspj(double *p,int n) 】 入口参数: *p : 数据数组指针 n : 数据个数 核心语句: 求平均数: for(i=0;in;i++) { temp+=*p; p++; } temp=temp/n; 作用: 将每一个数据求和,然后求平均数。 2.2中位值算法:【 void zwz(double *p,int n) 】 入口参数:(同上) 核心语句: 冒泡排序: for(i=n-1;i0;i--) for(j=0;ji;j++) { if(*(p+j)*(p+j+1)) { temp=*(p+j); *(p+j)=*(p+j+1); *(p+j+1)=temp; } } 中位值 = *(p+(n/2)+(n%2)-1) 作用: 对输入数据进行排序(从小到大),然后取排序位数最中间的数即为中位值。 2.3去掉极值的算数平均值算法:【void qjsspj(double *p,int n) 】 入口参数:(同上) 核心语句: 冒泡排序:(同上) 求算术平均: for(i=1;in-1;i++) { temp+=*(p+i); } temp=temp/(n-2); 作用: 对输入数据进行排序(从小到大),然后对数据第2位到第(n-1)位进行求和后取平均值。 2.4滑动平均滤波算法:【void hdpj(double *p,int n) 】 入口参数:(同上) 要求输入: it : 滑动平均的数据个数 核心语句: 滑动平均: for(i=it-1;in;i++) { temp=0; for(j=i-it+1;j=i;j++) { temp+=*(p+j); } printf(%d , %lf\n,i-it+1,temp/it); } 作用: 标记i从(it-1)到n滑动,每滑动一次对第(i-it+1)到第i个数据(共it个数据)求和并取平均数,达到滑动滤波的效果。 2.5加权平均滤波算法:【void jqpj(double *p,int n) 】 入口参数:(同上) 要求输入: it : 滑动加权平均的数据个数 a[i] : 每一个数据的权重(共it个数) 核心语句: 对权重进行处理,使其和为1: for(i=0;iit;i++) a[i]=a[i]/temp; 求加权平均: for(i=it-1;in;i++) { temp=0; for(j=i-it+1;j=i;j++) { temp+=(*(p+j))*(a[j+it-i-1]); } printf(%d , %lf\n,i-it+1,temp); } 作用: 在上一个“滑动平均滤波器”的基础上,对滑动的区间内的的每一个数据进行加权,然后求平均数,即为加权滑动平均滤波。 2.6数字低通滤波器:【void szdt(double *p,int n) 】 入口参数:(同上) 要求输入: high : 低通滤波器的数据截止上限 核心语句: 低通滤波器: for(i=0;in;i++) { if(*(p+i)-high0.00001) printf(%d , %lf\n,i,high); else printf(%d , %lf\n,i,*(p+i)); } 作用: 将每一个数据与截止上限进行比较,小于等于上限的直接输出,大于上线的数据进行截止,输出截止上限的数值,即为低通滤波。 2.7具有快速响应的数字滤波器

文档评论(0)

docinpfd + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:5212202040000002

1亿VIP精品文档

相关文档