⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lpfilt.f

📁 lpc 2400 bps语音编解码程序
💻 F
字号:
************************************************************************
*
*	LPFILT Version 55
*
************************************************************************
*
*   31 Point Equiripple FIR Low-Pass Filter
*     Linear phase, delay = 15 samples
*
*	Passband:  ripple = 0.25 dB, cutoff =  800 Hz
*	Stopband:  atten. =  40. dB, cutoff = 1240 Hz
*
* Inputs:
*  LEN    - Length of speech buffers
*  NSAMP  - Number of samples to filter
*  INBUF  - Input speech buffer
* Output:
*  LPBUF  - Low passed speech buffer
*
	subroutine lpfilt(inbuf, lpbuf, len, nsamp)
	integer len, nsamp, j
	real inbuf(len), lpbuf(len), t
	real h0,h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15
	parameter (h0  = -0.0097201988,
     1             h1  = -0.0105179986,
     1             h2  = -0.0083479648,
     1             h3  =  0.0005860774,
     1             h4  =  0.0130892089,
     1             h5  =  0.0217052232,
     1             h6  =  0.0184161253,
     1             h7  =  0.0003397230,
     1             h8  = -0.0260797087,
     1             h9  = -0.0455563702,
     1             h10 = -0.0403068550,
     1             h11 =  0.0005029835,
     1             h12 =  0.0729262903,
     1             h13 =  0.1572008878,
     1             h14 =  0.2247288674,
     1             h15 =  0.2505359650 )

	do j = len+1-nsamp,len
	    t =     h0 * (inbuf(j)    + inbuf(j-30))
	    t = t + h1 * (inbuf(j-1)  + inbuf(j-29))
	    t = t + h2 * (inbuf(j-2)  + inbuf(j-28))
	    t = t + h3 * (inbuf(j-3)  + inbuf(j-27))
	    t = t + h4 * (inbuf(j-4)  + inbuf(j-26))
	    t = t + h5 * (inbuf(j-5)  + inbuf(j-25))
	    t = t + h6 * (inbuf(j-6)  + inbuf(j-24))
	    t = t + h7 * (inbuf(j-7)  + inbuf(j-23))
	    t = t + h8 * (inbuf(j-8)  + inbuf(j-22))
	    t = t + h9 * (inbuf(j-9)  + inbuf(j-21))
	    t = t + h10* (inbuf(j-10) + inbuf(j-20))
	    t = t + h11* (inbuf(j-11) + inbuf(j-19))
	    t = t + h12* (inbuf(j-12) + inbuf(j-18))
	    t = t + h13* (inbuf(j-13) + inbuf(j-17))
	    t = t + h14* (inbuf(j-14) + inbuf(j-16))
	    t = t + h15 * inbuf(j-15)
	    lpbuf(j) = t
	end do

	return
	end	

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -