打印
[DSP编程]

IIR数字滤波器实现程序

[复制链接]
1003|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
xzy03101271|  楼主 | 2015-11-10 19:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
这是从书上还有很多网上资料找的说的比较多的IIR程序,我觉得这个程序有问题啊,程序里面fYn应该一直是0啊!!!
#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
#include "DSP281x_Examples.h"   // DSP281x Examples Include File
#include "f2812a.h"
#include"math.h"

#define IIRNUMBER 2
#define SIGNAL1F 1000
#define SIGNAL2F 4500
#define SAMPLEF  10000
#define PI 3.1415926

float InputWave();
float IIR();

float fBn[IIRNUMBER]={ 0.0,0.7757 };
float fAn[IIRNUMBER]={ 0.1122,0.1122 };
float fXn[IIRNUMBER]={ 0.0 };
float fYn[IIRNUMBER]={ 0.0 };
float fInput,fOutput;
float fSignal1,fSignal2;
float fStepSignal1,fStepSignal2;
float f2PI;
int i;
float fIn[256],fOut[256];
int nIn,nOut;

main(void)
{
   
           nIn=0; nOut=0;
        f2PI=2*PI;
        fSignal1=0.0;
        fSignal2=PI*0.1;
//        fStepSignal1=2*PI/30;
//        fStepSignal2=2*PI*1.4;
        fStepSignal1=2*PI/50;
        fStepSignal2=2*PI/2.5;
        while ( 1 )
        {
                fInput=InputWave();
                fIn[nIn]=fInput;
                nIn++; nIn%=256;
                fOutput=IIR();
                fOut[nOut]=fOutput;
                nOut++;
                if ( nOut>=256 )
                {
                        nOut=0;                /* 请在此句上设置软件断点 */
                }
        }
}        


float InputWave()
{
        for ( i=IIRNUMBER-1;i>0;i-- )
        {
                fXn[i]=fXn[i-1];
                fYn[i]=fYn[i-1];
        }
        fXn[0]=sin(fSignal1)+cos(fSignal2)/6.0;
        fYn[0]=0.0;
        fSignal1+=fStepSignal1;
        if ( fSignal1>=f2PI )        fSignal1-=f2PI;
        fSignal2+=fStepSignal2;
        if ( fSignal2>=f2PI )        fSignal2-=f2PI;
        return(fXn[0]);
}

float IIR()
{
        float fSum;
        fSum=0.0;
        for ( i=0;i<IIRNUMBER;i++ )
        {
                fSum+=(fXn[i]*fAn[i]);
                fSum+=(fYn[i]*fBn[i]);
        }
        return(fSum);
}


相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

38

主题

97

帖子

1

粉丝