二阶陷波器c语言实现

二阶陷波器c语言实现,第1张

下面介绍主要算法:

#include<math.h>

#define FIRNUMBER 25

#define SIGNAL1F 1000

#define SIGNAL2F 4500

#define SAMPLEF 10000

#define PI 3.1415926

float InputWave()

float FIR()

float fHn[FIRNUMBER]={ 0.0,0.0,0.001,-0.002,-0.002,0.01,-0.009,

-0.018,0.049,-0.02,0.11,0.28,0.64,0.28,

-0.11,-0.02,0.049,-0.018,-0.009,0.01,

-0.002,-0.002,0.001,0.0,0.0

}

float fXn[FIRNUMBER]={ 0.0 }

float fInput,fOutput

float fSignal1,fSignal2

float fStepSignal1,fStepSignal2

float f2PI

int i

float fIn[256],fOut[256]

int nIn,nOut

main()

{

nIn=0nOut=0

f2PI=2*PI

fSignal1=0.0

fSignal2=PI*0.1

fStepSignal1=2*PI/30

fStepSignal2=2*PI*1.4

while ( 1 )

{

fInput=InputWave()

fIn[nIn]=fInput

nIn++nIn%=256

fOutput=FIR()

fOut[nOut]=fOutput

nOut++

if ( nOut>=256 )

{

nOut=0 /* 请在此句上设置软件断点 */

}

}

}

float InputWave()

{

for ( i=FIRNUMBER-1i>0i-- )

fXn[i]=fXn[i-1]

fXn[0]=sin(fSignal1)+cos(fSignal2)/6.0

fSignal1+=fStepSignal1

if ( fSignal1>=f2PI )fSignal1-=f2PI

fSignal2+=fStepSignal2

if ( fSignal2>=f2PI )fSignal2-=f2PI

return(fXn[0])

}

float FIR()

{

float fSum

fSum=0

for ( i=0i<FIRNUMBERi++ )

{

fSum+=(fXn[i]*fHn[i])

}

return(fSum)

}

如果是低频电路就好办了.

首先你要做的是一个滤波器的设计,这个滤波器是带阻滤波器.不过你还是要确定你的滤波器的过度带宽度,因为过度带宽度越大,那么谐振电路的级数也就越少,成本也小

然后是计算参数,根据阻抗匹配原理姿悄,确定你使用的是串联谐振还是并联谐振电路

计算好参数,最好用尘仿计算机算吧.把滤波器参数转换为电感电容还有电阻的参数,你可以参考滤波器方面的书

大致是这样

不迹兄渣过这只是我的想法,在你的设计中,能不能用这样的滤波器替代我就不清楚了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12280343.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存