最近在做轴承故障检测,C语言编程,在滤波部分遇到了问题,由于本人对滤波知之甚少,想求助:

这是测得的振动信号,在这个基础上我分别用C语言与LabVIEW对其做了滤波,都是用iir巴特沃兹滤波,频域上两者结果一样(我就不放图了),但时域差距很大。

这是LabVIEW做得滤波之后的时域图像看上去很正常,iir巴特沃兹滤波3阶

这是C语言同样采用iir巴特沃兹滤波的时域结果,非常不像。为什么会出现这样的问题。C语言是用的双线性变换

void iirbcf(short ifilt,short band,short ns,short n,double f1,double f2,double f3,double f4,double db,double b[],double a[])

{

short k;

double omega,lamda,epslon,fl,fh;

double d[5],c[5];

if((band==1)||(band==4)) fl=f1;

if((band==2)||(band==3)) fl=f2;

if(band<=3) fh=f3;

if(band==4) fh=f4;

if(ifilt<3)

{ switch (band)

{ case 1:

case 2:

{ omega=warp(f2)/warp(f1);

break;

}

case 3:

{ omega=omin(bpsub(warp(f1),fh,fl),bpsub(warp(f4),fh,fl));

break;

}

case 4:

{ omega=omin(1.0/bpsub(warp(f2),fh,fl),1.0/bpsub(warp(f3),fh,fl));}

}

lamda=pow(10.0,(db/20.0));

epslon=lamda/cosh(2*ns*cosh1(omega));

}

for(k=0;k

{ switch(ifilt)

{ case 1:

{ chebyi(2*ns,k,4,epslon,d,c);

break;

}

case 2:

{ chebyii(2*ns,k,4,omega,lamda,d,c);

break;

}

case 3:

{ bwtf(2*ns,k,4,d,c);

break;

}

}

fblt(d,c,n,band,fl,fh,&b[k*(n+1)+0],&a[k*(n+1)+0]);

}

}

double cosh1(double x)

{ double z;

z=log(x+sqrt(x*x-1.0));

return(z);

}

double warp(double f)

{ double pi,z;

pi=4.0*atan(1.0);

z=tan(pi*f);

return(z);

}

double bpsub(double om,double fh,double fl)

{ double z;

z=(om*om-warp(fh)*warp(fl))/(warp(fh)-warp(fl)*om);

return(z);

}

double omin(double om1,double om2)

{ double z,z1,z2;

z1=fabs(om1);

z2=fabs(om2);

z=(z1

return(z);

}

void bwtf(short ln,short k,short n,double d[],double c[])

{ short i;

double pi,tmp;

pi=4.0*atan(1.0);

d[0]=1.0;

c[0]=1.0;

for(i=1;i<=n;i++)

{

d[i]=0.0;

c[i]=0.0;

}

tmp=(k+1)-(ln+1.0)/2.0;

if(tmp==0.0)

{ c[1]=1.0;

}

else

{

c[1]=-2.0*cos((2*(k+1)+ln-1)*pi/(2*ln));

c[2]=1.0;

}

}

void chebyi(short ln,short k,short n,double ep,double d[],double c[])

{ short i;

double pi,gam,omega,sigma;

pi=4.0*atan(1.0);

gam=pow(((1.0+sqrt(1.0+ep*ep))/ep),1.0/ln);

sigma=0.5*(1.0/gam-gam)*sin((2*(k+1)-1)*pi/(2*ln));

omega=0.5*(1.0/gam+gam)*cos((2*(k+1)-1)*pi/(2*ln));

for (i=0;i<=n;i++)

{ d[i]=0.0;

c[i]=0.0;

}

if (((ln%2)==1)&&((k+1)==(ln+1)/2))

{ d[0]=-sigma;

c[0]=d[0];

c[1]=1.0;

}

else

{ c[0]=sigma*sigma+omega*omega;

c[1]=-2.0*sigma;

c[2]=1.0;

d[0]=c[0];

if(((ln%2)==0)&&(k==0))

d[0]=d[0]/sqrt(1.0+ep*ep);

}

}

void chebyii(short ln,short k,short n,double ws,double att,double d[],double c[])

{ short i;

double pi,gam,alpha,beta,sigma,omega,scln,scld;

pi=4.0*atan(1.0);

gam=pow((att+sqrt(att*att-1.0)),1.0/ln);

alpha=0.5*(1.0/gam-gam)*sin((2*(k+1)-1)*pi/(2*ln));

beta=0.5*(1.0/gam+gam)*cos((2*(k+1)-1)*pi/(2*ln));

sigma=ws*alpha/(alpha*alpha+beta*beta);

omega=-1.0*ws*beta/(alpha*alpha+beta*beta);

for (i=0;i<=n;i++)

{ d[i]=0.0;

c[i]=0.0;

}

if(((ln%2)==1)&&((k+1)==(ln+1)/2))

{ d[0]=-1.0*sigma;

c[0]=d[0];

c[1]=1.0;

}

else

{ scln=sigma*sigma+omega*omega;

scld=pow((ws/cos((2*(k+1)-1)*pi/(2*ln))),2);

d[0]=scln*scld;

d[2]=scln;

c[0]=d[0];

c[1]=-2.0*sigma*scld;

c[2]=scld;

}

}

void fblt(double d[],double c[],short n,short band,double fln,double fhn,double b[],double a[])

{

short i,k,m,n1,n2,ls;

double pi,w,w0,w1,w2,tmp,tmpd,tmpc,*work;

pi=4.0*atan(1.0);

w1=tan(pi*fln);

for(i=n;i>=0;i--)

{ if((c[i]!=0.0)||(d[i]!=0.0))

break;

}

m=i;

switch (band)

{

case 1:

case 2:

{ n2=m;

n1=n2+1;

if(band==2)

{ for(i=0;i<=m/2;i++)

{ tmp=d[i];

d[i]=d[m-i];

d[m-i]=tmp;

tmp=c[i];

c[i]=c[m-i];

c[m-i]=tmp;

}

}

for(i=0;i<=m;i++)

{

d[i]=d[i]/pow(w1,i);

c[i]=c[i]/pow(w1,i);

}

break;

}

case 3:

case 4:

{n2=2*m;

n1=n2+1;

work=malloc(n1*n1*sizeof(double));

w2=tan(pi*fhn);

w=w2-w1;

w0=w1*w2;

if(band==4)

{ for(i=0;i<=m/2;i++)

{ tmp=d[i];

d[i]=d[m-i];

d[m-i]=tmp;

tmp=c[i];

c[i]=c[m-i];

c[m-i]=tmp;

}

}

for(i=0;i<=n2;i++)

{ work[0*n1+i]=0.0;

work[1*n1+i]=0.0;

}

for(i=0;i<=m;i++)

{tmpd=d[i]*pow(w,(m-i));

tmpc=c[i]*pow(w,(m-i));

for(k=0;k<=i;k++)

{ ls=m+i-2*k;

tmp=combin(i,i)/(combin(k,k)*combin(i-k,i-k));

work[0*n1+ls]+=tmpd*pow(w0,k)*tmp;

work[1*n1+ls]+=tmpc*pow(w0,k)*tmp;

}

}

for(i=0;i<=n2;i++)

{d[i]=work[0*n1+i];

c[i]=work[1*n1+i];

}

free(work);

}

}

bilinear(d,c,b,a,n);

}

double combin(short i1,short i2)

{ short i;

double s;

s=1.0;

if(i2==0) return (s);

for(i=i1;i>(i1-i2);i--)

{ s*=i; }

return (s);

}

void bilinear(double d[],double c[],double b[],double a[],short n)

{short i,j,n1;

double sum,atmp,scale, *temp;

n1=n+1;

temp=malloc(n1*n1*sizeof(double));

for(j=0;j<=n;j++)

{

temp[j*n1+0]=1.0;

}

sum=1.0;

for(i=1;i<=n;i++)

{

sum=sum*(double)(n-i+1)/(double)i;

temp[0*n1+i]=sum;

}

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

{ temp[j*n1+i]=temp[(j-1)*n1+i]-temp[j*n1+i-1]-temp[(j-1)*n1+i-1];

}

for(i=n;i>=0;i--)

{ b[i]=0.0;

atmp=0.0;

for(j=0;j<=n;j++)

{ b[i]=b[i]+temp[j*n1+i]*d[j];

atmp=atmp+temp[j*n1+i]*c[j];

}

scale=atmp;

if(i!=0) a[i]=atmp;

}

for(i=0;i<=n;i++)

{ b[i]=b[i]/scale;

a[i]=a[i]/scale;

}

a[0]=1.0;

free(temp);

}

这是C语言滤波程序,我只用了里面的巴特沃兹

iir滤波器c语言程序,请教C语言做iir滤波器问题相关推荐

  1. c语言中x的n次幂程序,请教c语言关于X的N次幂问题?

    请教c语言关于X的N次幂问题? 程序填空,不要改变与输入输出有关的语句. 输入一个正整数repeat (0 读入1 个正实数x和1个正整数 n(n<=50),计算并输出x的n次幂(保留2位小数) ...

  2. c语言 程序循环,C语言程序设计-循环例子

    <C语言程序设计-循环例子>由会员分享,可在线阅读,更多相关<C语言程序设计-循环例子(28页珍藏版)>请在人人文库网上搜索. 1.C 语言程序设计基础篇,第 7 章 简单程序 ...

  3. 简单说明c语言程序步骤,C语言的入门简介和三个简单的C语言程序详细说明

    学习一种编程语言,最重要的是建立一个练习环境,边学边练才能学好.Keil软件是目前最流行开发80C51系列单片机的软件,Keil提供了包括C编译器.宏汇编.连接器.库管理和一个功能强大的仿真调试器等在 ...

  4. c语言程序前言,C语言 程序代码编写规范前言

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 一个好的程序编写规范是编写高质量程序的保证.清晰.规范的源程序不仅仅是方便阅读,更重要的是能够便于检查错误,提高调试效率,从而最终保证软件的质量和可维护性 ...

  5. c语言程序基本设计,C语言程序的设计基本6.ppt

    C语言程序的设计基本6 第六章 本章要点 建立循环程序设计的基本概念和逻辑思维 掌握循环程序设计的方法 6.1 if-goto 语句循环 一般形式: goto 标号: 标号:语句 其中:标号用标识符表 ...

  6. c语言 程序结集,c语言(结体程序设计).doc

    c语言(结体程序设计) C语言程序设计实验报告 实验七.结构体程序设计 [实验目的] (1)掌握结构体类型的概念.定义和使用: (2)掌握结构体数组.结构体指针的定义和使用: [实验内容及步骤] 1. ...

  7. 情人节c语言程序,情人节c语言代码.doc

    情人节c语言代码 篇一:一些简单的C语言程序代码 由键盘任意输入1个4位数整数,分别输出其中的个位.十位.百位.千位. /* expe 3-10 */ #include #include void m ...

  8. 好听的歌曲单片机c语言程序,单片机C语言程序举例(三)

    原标题:单片机C语言程序举例(三) 14.音乐播放 //此程序在硬件上调试通过 //本程序的晶振采用11.0592M #include sbit speaker=P1^2; unsigned char ...

  9. c 语言程序编辑,C语言程序编辑学习篇—编程者说之C语言

    谈及C语言,我想凡是学过它的朋友都有这样一种感觉,那就是"让我欢喜让我忧."欢喜的是,C语言功能非常强大.应用广泛,一旦掌握了后,你就可以理直气壮地对他人说"我是电脑高手 ...

  10. c语言程序培训,C语言编程培训学习心得

    说到C语言学习真的是千言万语,可以说C语言在世界语言排行榜中位居前列,像一些操作系统.驱动软件.多媒体软件.大型游戏. 杀毒软件等等软件操作系统,都是C\C++的特区,对于其他语言来讲真的是望尘莫及. ...

最新文章

  1. 方差协方差以及协方差矩阵
  2. 1087 All Roads Lead to Rome (30 分)【难度: 一般 / Dijkstra】
  3. 万能系统卸载器免root_这下舒服了!一键卸载安卓全机型预装应用
  4. AOJ 558 Cheese(bfs)
  5. 十分钟搭建自己的私有NuGet服务器-BaGet
  6. selenium webdriver python 元素操作
  7. 计算机基础知识二进制转换,计算机基础知识数制转换
  8. PXE(preboot execute environment)
  9. 安卓中圆角背景图被拉伸的解决方案——.9.png
  10. 查看磁盘阵列 使用率(简单)
  11. Java常用类(四):IOUtils类
  12. 全国ps计算机考试时间,全国计算机考试一级PS考试大纲
  13. 各国货币名称中英对照
  14. 遥感原始图像计算机格式,卫星遥感影像数据是什么样格式的?
  15. 信佛的人对佛教的诘问
  16. 如何使用报表工具设置页眉与页脚
  17. 和平精英吃鸡捏脸数据助手微信小程序源码
  18. HGAME 2022 week1 个人部分WP
  19. HTML + Css实现页面特效
  20. VC实现二维码(qrcode)编码源码

热门文章

  1. VS2010免注册调用大漠插件
  2. Oracle客户端安装教程(图文)
  3. 一位老电子工程师的十年职场感悟
  4. 计算机网络校园网建设设计摘要,计算机网络专业毕业论文校园网建设设计.doc...
  5. 2021 OpenCV人工智能竞赛优秀项目团队介绍集锦(五)
  6. Fedora9下codeblocks安装无法编译的问题
  7. Exchange 2010 用户邮箱使用空间统计
  8. 基于SURF算法的图像拼接方法
  9. 网吧游戏服务器制作教程,网吧服务器系统环境部署
  10. 计算机图片组合快捷键,Windows电脑常用的10个Win组合快捷键功能,看看你都知道吗?...