|
DSP Master VCL
|
Design an oversampled FIR filter with rectangular window.
procedure FractionalFirImpulse(Length: integer; const H: TVec; const W: array of double; Offset: double; Step: double; FilterType: TFilterType; FS: double = 2); overload;
Compute a FIR impulse response filter (no window applied) and place the result in H. The transition regions are defined with the W array. There must be at least one (lowpass, highpass) and at most two (bandpass, bandstop) transition regions (2 or 4 elements). Filter type is defined with TFilterType. 20*Log10(Ripple) is also the required attenuation of the stop band in decibel. FS is the sampling frequency. Length specifies the length of the original filter and Step defines the oversampling factor. The actual length of the impulse response vector is computed like this: H.Length := Round(Length/Step) Step and offset must be bigger then 0. If the Offest is 0 and step is 1, the routine returns the same result as FirImpulse. The resulting H vector contains FIR type impulse response, which can be passed to an interpolation routine (linear, cubic, lagrange, etc..). Oversampled FIR filters are used for resampling with an arbitrary sampling frequency and, if Offset > 0 and Step = 1, fractional delay FIR filters can be implemented. If Step = 1 then the resulting impulse response can be passed directly to the FirInit and FirFilter routines. When setting Step bigger then 1, the filter designed must also work as an anti-aliasing filter (low-pass) or aliasing will occur.
FirImpulse, KaiserImpulse, FractionalKaiserImpulse, FractionalFirImpulse
Filter interpolation.
uses MtxExpr, Math387, MtxVec, SignalUtils, MtxVecTee, MtxVecEdit; procedure TForm1.Button1Click(Sender: TObject); var h,X: Vector; Step,FS: double; begin FS := 2; Step := 1; //interpolate by 1x FractionalFirImpulse(30,H,[0.5,0.6],0,Step,ftLowpass,FS); X := Ramp(H,0,1.0/H.Length); DrawIt(X,H,'Interpolate by 1x'); Step := 0.5; //interpolate by 2x FractionalFirImpulse(30,H,[0.5,0.6],0,Step,ftLowpass,FS); X := Ramp(H,0,1.0/H.Length); DrawIt(X,H,'Interpolate by 2x'); Step := 0.25; //interpolate by 4x FractionalFirImpulse(30,H,[0.5,0.6],0,Step,ftLowpass,FS); X := Ramp(H,0,1.0/H.Length); DrawIt(X,H,'Interpolate by 4x'); Step := 0.125; //interpolate by 8x FractionalFirImpulse(30,H,[0.5,0.6],0,Step,ftLowpass,FS); X := Ramp(H,0,1.0/H.Length); DrawIt(X,H,'Interpolate by 8x'); end;
#include "MtxExpr.hpp" #include "MtxVecEdit.hpp" #include "MtxVecTee.hpp" #include "SignalUtils.hpp" void __fastcall TForm1::BitBtn1Click(TObject *Sender) { sVector H,X; double FS = 2; double Step = 1; //interpolate by 1x FractionalFirImpulse(30,H,OPENARRAY(double,(0.5,0.6)),0,Step,ftLowpass,FS); X = Ramp(H,0,1.0/H.Length); DrawIt(X,H,"Interpolate by 1x",false); Step = 0.5; //interpolate by 2x FractionalFirImpulse(30,H,OPENARRAY(double,(0.5,0.6)),0,Step,ftLowpass,FS); X = Ramp(H,0,1.0/H.Length); DrawIt(X,H,"Interpolate by 2x",false); Step = 0.25; //interpolate by 4x FractionalFirImpulse(30,H,OPENARRAY(double,(0.5,0.6)),0,Step,ftLowpass,FS); X = Ramp(H,0,1.0/H.Length); DrawIt(X,H,"Interpolate by 4x",false); Step = 0.125; //interpolate by 8x FractionalFirImpulse(30,H,OPENARRAY(double,(0.5,0.6)),0,Step,ftLowpass,FS); X = Ramp(H,0,1.0/H.Length); DrawIt(X,H,"Interpolate by 8x",false); }
|
Copyright (c) 1999-2025 by Dew Research. All rights reserved.
|
|
What do you think about this topic? Send feedback!
|