2013-05-02 141 views
0

这是我的第一个问题(编码相当新颖),所以会尝试尽可能多地包含信息,因为我现在很难过!预期声明

我正在尝试编写代码,该代码将创建butterworth过滤器以适合用户输入规范。我使用的Code Composer 4.

让Google有54个错误,我有一个持续1个左:

"expected a declaration" on line 27: if (n=1 && hpf=0) 

我有三重检查大括号,任何想法?

编辑:

嗨,再次感谢所有的帮助。自那时起就排序了很多旧问题,但又一次撞上了一堵砖墙;代码将不会写入coffic.cof文件(或者在文件被删除时创建)。没有错误出现,但文件保持不变。任何想法?

P.S.遗憾前面的代码布局 - 希望这是更好的:

#include "dsk6713_aic23.h"  //codec-DSK support file 
Uint32 fs=DSK6713_AIC23_FREQ_8KHZ; //set sampling rate 
# include <stdio.h> 
# include <math.h> 
# include <stdlib.h> 
#define pi 3.1415927 
#include "coffic.cof" 

void main() 
{ 
    double hpf, fs, fco, atn, fat, tp, k, ad, m, n, o, da, db, dc; 
    FILE *fp; 
    int c, d, e, f, g, h, i, q, r, s, t, u, v; 
    hpf = 0;   //for a high-pass filter input 1, for a low-pass filter input 0 
    fs = 8000;   //input samping frequency here 
    fco = 2400;   //input cut-off frequency here 
    atn = 17;   //input attenuation (dB) here 
    fat = 3500;   //input the frequency of attenuation here 
    tp = 1/fs; 
    k = tan(pi*fco*tp); 
    ad = tan(pi*fat*tp); 
    m = (log10((pow(10,(atn/10)))-1))/(2*(log10(ad/k))); 
    o = abs(m); 
    n = ceil(o); 

    da = 1.414; 
    c = (pow(2,15)*k*k/(1+da*k+k*k)); 
    d = (pow(2,15)*2*k*k/(1+da*k+k*k)); 
    e = (pow(2,15)*k*k/(1+da*k+k*k)); 
    q = (pow(2,15)*(2-2*k*k)/(1+da*k+k*k)); 
    r = (pow(2,15)*(-1+k-k*k)/(1+da*k+k*k)); 

    fp = fopen("U:\DSK6713\Ivo\CSP\coffic.cof", "w"); 
    if (fp == NULL) 
    { 
     printf("Error. Unable to open coffic.cof"); 
     exit(0); 
    } 

    fprintf(fp, "int a[3]={%d, d%, %d};\n", c, d, e); 
    fprintf(fp, "int b[3]={1, d%, %d};\n", q ,r); 
    fprintf(fp, "int x[3]={0,0,0};\nint y[3]={0,0,0};\n"); 

    fflush(fp); 

    fclose(fp); 

    comm_intr();     //init DSK, codec, McBSP 
    while(1);      //infinite loop 
} 

interrupt void c_int11()   //interrupt service routine 
{ 
    short input; 
    FILE *fp; 
    fp = fopen("U:\DSK6713\Ivo\CSP\coffic.cof", "r"); 
    if (fp == NULL) 
    { 
     printf("Error. Unable to open coffic.cof"); 
     exit(0); 
    } 

    fclose(fp); 

    x[2]=x[1]; 
    x[1]=x[0]; 
    y[2]=y[1]; 
    y[1]=y[0]; 

    input=input_sample(); 
    x[0]=input; 

    y[0]=a[0]*x[0]+a[1]*x[1]+a[2]*x[2]+b[1]*y[1]+b[2]*x[2];  

    y[0]=y[0]>>15;      
    input=(short)y[0]; 
    output_sample(input); //output data 
    return; 
} 
+0

您的所有代码都必须在函数内。你不能在顶层有这样的if。并请缩进您的代码。 – Mat 2013-05-02 11:01:28

+0

你应该缩进和格式化你的代码,这很可怕,不可读。此外,你没有指出哪一行是第27行。 – 2013-05-02 11:01:36

+0

我的眼睛......他们在流血。 – holgac 2013-05-02 12:14:45

回答

0

此外,它看起来像你的程序缺乏main()功能,其在顶层(任何函数之外)代码这是不允许的。

主程序应在调用的函数:

int main(void) 

,因为这是执行将启动。

另外,C中的比较运算符拼写为==。单一=被分配。

+0

这是一个很好的观点,但这并不能解决这个错误。 – Mat 2013-05-02 11:02:12

0

您正尝试在main之外执行一些代码,而不是声明为函数。您需要将所有代码放在主要位置。在第27行,您已关闭main,并且未将您的下一个陈述声明为函数。所以

#include "dsk6713_aic23.h"  //codec-DSK support file 
Uint32 fs=DSK6713_AIC23_FREQ_8KHZ; //set sampling rate 
# include <stdio.h> 
# include <math.h> 
# include <stdlib.h> 
#define pi 3.1415927 

int main(int argc, char *argv[]) 
{ 
double hpf, fs, fco, atn, fat, tp, k, ad, m, n, o, da, db, dc; 
int c, d, e, f, g, h, i, q, r, s, t, u, v; 
hpf = 0;   //for a high-pass filter input 1, for a low-pass filter input 0 
fs = 8000;   //input samping frequency here 
fco = 2400;   //input cut-off frequency here 
atn = 17;   //input attenuation (dB) here 
fat = 3500;   //input the frequency of attenuation here 
tp = 1/fs; 
k = tan(pi*fco*tp); 
ad = tan(pi*fat*tp); 
m = (log10((pow(10,(atn/10)))-1))/(2*(log10(ad/k))); 
o = abs(m); 
n = ceil(o); 


if (n == 1 && hpf == 0) 
{ 
    int  a[2]={c,d}; 
    int  b[2]={1,q}; 
    int  x[2]={0,0}; 
    int  y[2]={0,0}; 
    c = (pow(2,15)*k/(k+1)); 
    d = (pow(2,15)*k/(k+1)); 
    q = (pow(2,15)*(1-k)/(k+1)); 
} 

else if (n == 2 && hpf == 0) 
{ 
    da = 1.414; 
    int  a[3]={c,d,e}; 
    int  b[3]={1,q,r}; 
    int  x[3]={0,0,0}; 
    int  y[3]={0,0,0}; 
    c = (pow(2,15)*k*k/(1+da*k+k*k)); 
    d = (pow(2,15)*2*k*k/(1+da*k+k*k)); 
    e = (pow(2,15)*k*k/(1+da*k+k*k)); 
    q = (pow(2,15)*(2-2*k*k)/(1+da*k+k*k)); 
    r = (pow(2,15)*(-1+k-k*k)/(1+da*k+k*k)); 
} 

else 
{ 
    puts("Sorry, the parameters you have entered cannot be met by a Butterworth Filter of order 6 or less."); 
} 

    comm_intr();     //init DSK, codec, McBSP 
    while(1);      //infinite loop 

} // closing brace of main 

interrupt void c_int11()   //interrupt service routine 
{ 
short input; 

x[1]=x[0]; 
y[1]=y[0]; 

input=input_sample(); 
x[0]=input; 

y[0]=a[0]*x[0]+a[1]*x[1]+b[1]*y[1];  

y[0]=y[0]>>15;      
input=(short)y[0]; 
output_sample(input); //output data 
return; 
} 

而你没有比较,但分配。更改为

if (n == 1 && hpf == 0){ } 

正如小hint

如果执行

if(n = 1) 

这是一个有效的表达,而是一种分配,并会在这种特殊情况下返回true,但它总是返回true。 鉴于

if (n == 1) 

是一个比较和将或者产生true如果n等于1或假,如果n不等于1

0

那是什么大括号经过n =小区(O)做?

您正在结束主函数,它将if语句留在函数作用域之外。

删除大括号,代码应该工作。

此外,在if语句中使用==代替=。 =将赋值给你的变量,顺便说一句,它们总是返回true,==实际上会比较它们。