if nargin < 6 w='tz'; if nargin < 5 fh=0.5; if nargin < 4 fl=0; end end end f0=700/fs; fn2=floor(n/2); lr=log((f0+fh)/(f0+fl))/(p+1); % convert to fft bin numbers with 0 for DC term bl=n*((f0+fl)*exp([0 1 p p+1]*lr)-f0); b2=ceil(bl(2)); b3=floor(bl(3)); if any(w=='y') pf=log((f0+(b2:b3)/n)/(f0+fl))/lr; fp=floor(pf); r=[ones(1,b2) fp fp+1 p*ones(1,fn2-b3)]; c=[1:b3+1 b2+1:fn2+1]; v=2*[0.5 ones(1,b2-1) 1-pf+fp pf-fp ones(1,fn2-b3-1) 0.5]; mn=1; mx=fn2+1; else b1=floor(bl(1))+1; b4=min(fn2,ceil(bl(4)))-1; pf=log((f0+(b1:b4)/n)/(f0+fl))/lr; fp=floor(pf); pm=pf-fp; k2=b2-b1+1; k3=b3-b1+1; k4=b4-b1+1; r=[fp(k2:k4) 1+fp(1:k3)]; c=[k2:k4 1:k3]; v=2*[1-pm(k2:k4) pm(1:k3)]; mn=b1+1; mx=b4+1; end if any(w=='n') v=1-cos(v*pi/2); elseif any(w=='m') v=1-0.92/1.08*cos(v*pi/2); end if nargout > 1 x=sparse(r,c,v); else x=sparse(r,c+mn-1,v,p,1+fn2); end
时间: 2024-04-23 16:26:57 浏览: 97
这段代码实现了一个计算带通滤波器参数的函数。具体来说,输入参数有6个,分别是fs(采样率)、n(fft点数)、p(滤波器阶数)、fl(通带下边缘频率)、fh(通带上边缘频率)、w(窗函数类型)。
函数的作用是计算一个带通滤波器的系数,这个滤波器可以用来过滤输入信号,只保留在fl和fh之间的频率成分。函数中的参数计算方法基于一种名为“三角形滤波器”的滤波器设计方法,这种方法可以使得通带内的频率响应呈三角形状,从而更加接近人耳的听觉特性。
具体实现中,代码根据输入参数计算了滤波器的截止频率,并将其转换为fft bin的序号。然后,根据窗函数类型,计算了滤波器的系数,最后将其打包成一个稀疏矩阵的形式返回。如果输出参数大于1,则返回的矩阵包含系数矩阵和频率向量。如果输出参数为1,则只返回系数矩阵。
阅读全文