| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 551 人关注过本帖
标题:出了点问题关于C++的。
只看楼主 加入收藏
d529684722
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-5-4
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
出了点问题关于C++的。
#include"math.h"
#include"stdio.h"

/*n:滤波器的阶数,n是奇数时可用来设计各种滤波器
band:滤波器类型1、2、3、4分别对应低通,高通,带通,带阻
fln:通带下边界频率
fhn:通带下边界频率
wn:窗函数的类型1-7分别对应
h:长度为n+1,存放滤波器的系数
fs:采样频率*/

void firwin(n;band;fln;fhn;wn;h)
int n,band,wn;
double fln,fhn,h[];

{int i,n2,mid;
 double s,pi,wc1,wc2,beta,delay,fs;
 double window();//窗函数的计算
 beta=0.0;
if(wn==7)//只有凯塞窗需要输入系数beta
{ printf("input beta parameter of Kaiser window(2<beta<10)\n");
  scanf("%1f",&beta);
}
pi=4.0*atan(1.0);//pi=PI;

if((n%2)==0)/*如果阶数n是偶数*/
{n2=n/2+1;/**/
 mid=1;//
}
else
{n2=n/2;//n是奇数,则窗口长度为偶数
 mid=0;//
}
delay=n/2.0;
wc1=2.0*pi*fln;//
if(band>=3) wc2=2.0*pi*fhn;/*先判断用户输入的数据,如果band参数大于3*/
switch(band)
{case 1:
            {for(i=0;i<=n2;i++)
             {s=i-delay;//
              h[i]=(sin(wc1*s/fs)/(pi*s))*window(wn,n+1,i,beta);//低通,窗口长度=阶数+1,故为n+1
              h[n-i]=h[i];
                  }
              if(mid==1) h[n/2]=wc1/pi;//n为偶数时,修正中间值系数
              break;
               }
case 2:   
         { for(i=0;i<=n2;i++)
           {s=i-delay;
            h[i]=(sin(pi*s)-sin(wc1*s/fs))/(pi*s);//高通-//对
            h[i]=h[i]*window(wn,n+1,i,beta);
             h[n-i]=h[i];
            }
           if(mid==1) h[n/2]=1.0-wc1/pi;//对
           break;
          }

case 3:
            {for(i=0;i<n2;i++)
            {s=i-delay;
             h[i]=(sin(wc2*s/fs)-sin(wc1*s/fs))/(pi*s);//带通-//对
             h[i]=h[i]*window(wn,n+1,i,beta);
             h[n-i]=h[i];
               }
               if(mid==1)h[n/2]=(wc2-wc1)/pi;//对
              break;
               }
case 4:
               {for(i=0;i<=n2;i++)
               {s=i-delay;
               h[i]=(sin(wc1*s/fs)+sin(pi*s)-sin(wc2*s/fs))/(pi*s);//带阻-//对
               h[i]=h[i]*window(wn,n+1,i,beta);
               h[n-i]=h[i];
                }
               if(mid==1)h[n/2]=(wc1+pi-wc2)/pi;
               break;
               }
                 }
                }

/*返回窗函数的表达式
n:窗口长度
type:选择窗函数的类型
beta:生成凯塞窗的系数*/
static double window(type,n,i,beta)

int i,n,type;
double beta;
{int k;
double pi,w;
double kaiser();
pi=4.0*atan(1.0);//pi=PI;
w=1.0;

switch(type)
{case 1:
{w=1.0;//矩形窗
break;
}
case 2:
{k=(n-2)/10;
if(i<=k)
w=0.5*(1.0-cos(i*pi/(k+1)));//图基窗
break;
}
case 3:
{w=1.0-fabs(1.0-2*i/(n-1.0));//三角窗
break;
}
case 4:
{w=0.5*(1.0-cos(2*i*pi/(n-1)));//汉宁窗
break;
}
case 5:
{w=0.54-0.46*cos(2*i*pi/(n-1));//海明窗
break;
}
case 6:
{w=0.42-0.5*cos(2*i*pi/(n-1))+0.08*cos(4*i*pi/(n-1));//布莱克曼窗
break;
}
case 7:
{w=kaiser(i,n,beta);//凯塞窗
break;
}
}
return(w);
}
static double kaiser(i,n,beta)//因凯塞窗的表达式复杂,调用贝塞尔窗表达式
int i,n;
double beta;
{
double a,w,a2,b1,b2,beta1;
double bessel0();
b1=bessel0(beta);
a=2.0*i/(double)(n-1)-1.0;
a2=a*a;
beta1=beta*sqrt(1.0-a2);
b2=bessel0(beta1);
w=b2/b1;
return(w);
}

static double bessel0(x)
double x;
{int i;
double d,y,d2,sum;
y=x/2.0;
d=1.0;
sum=1.0;
for(i=1;i<=25;i++)
{d=d*y/i;
d2=d*d;
sum=sum+d2;
if(d2<sum*(1.0e-8)) break;
}
return(sum);
}





出现了:\Users\dell\Desktop\Text2.cpp(12) : error C2065: 'n' : undeclared identifier
C:\Users\dell\Desktop\Text2.cpp(12) : error C2143: syntax error : missing ')' before ';'
C:\Users\dell\Desktop\Text2.cpp(12) : error C2182: 'firwin' : illegal use of type 'void'
C:\Users\dell\Desktop\Text2.cpp(12) : error C2501: 'band' : missing storage-class or type specifiers
C:\Users\dell\Desktop\Text2.cpp(12) : error C2501: 'fln' : missing storage-class or type specifiers
C:\Users\dell\Desktop\Text2.cpp(12) : error C2501: 'fhn' : missing storage-class or type specifiers
C:\Users\dell\Desktop\Text2.cpp(12) : error C2501: 'wn' : missing storage-class or type specifiers
C:\Users\dell\Desktop\Text2.cpp(12) : error C2059: syntax error : ')'
C:\Users\dell\Desktop\Text2.cpp(13) : error C2144: syntax error : missing ';' before type 'int'
C:\Users\dell\Desktop\Text2.cpp(13) : error C2501: 'h' : missing storage-class or type specifiers
C:\Users\dell\Desktop\Text2.cpp(13) : fatal error C1004: unexpected end of file found。。。



怎么改?
搜索更多相关主题的帖子: include 滤波器 window double 
2013-05-04 14:50
apull
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:三体星系
等 级:版主
威 望:216
帖 子:1506
专家分:9241
注 册:2010-3-16
收藏
得分:20 
void firwin(n;band;fln;fhn;wn;h)
编译提示集中在12行,上面这句好好看看。
2013-05-04 16:45
d529684722
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-5-4
收藏
得分:0 
回复 楼主 d529684722
不知道怎么改动。求教。
2013-05-04 17:19
快速回复:出了点问题关于C++的。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019877 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved