You are here: Symbol Reference > SignalUtils Namespace > Functions > SignalUtils.FractionalFirImpulse Function
DSP Master VCL
ContentsIndex
PreviousUpNext
SignalUtils.FractionalFirImpulse Function

Design an oversampled FIR filter with rectangular window.

Pascal
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.

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!