Skip to content

tjr1/fir-window

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

###FIR Filter Design (Window)

Requirements: GSL, Qwt, DSP helper files (included), Boost library
Limitations: There is a limit to how high a filter order you can use. This module does not test if your filter order will break real-time.

FIR Window GUI

This module creates an in-line FIR filter that can be applied to any signal in RTXI. Given the desired number of filter taps (filter order + 1), it computes the impulse response for a lowpass, highpass, bandpass, or bandstop filter using the window method. For a lowpass or highpass filter, the module uses the first frequency as the cut-off frequency. For a bandpass or bandstop filter, both input frequencies are used to define the frequency band. The module initially computes an ideal FIR filter to which you can apply a Triangular (or Bartlett), Hamming, Hann, Kaiser, or Dolph-Chebyshev window. The Hann window is not to be confused with the Hanning window (see MATLAB’s hann() vs. hanning() functions). To apply no window to the filter, choose the Rectangular filter. The Kaiser and Chebyshev windows each take a parameter that determines the attenuation of the sidelobes in the filter. The algorithms only accept an odd number of filter taps. If you enter an even number, the module will automatically add 1 to the number of filter taps.

This module uses a circular buffer from the Boost library for storing recent input samples. You can install these libraries in Ubuntu with:

$ sudo apt-get install libboost-dev

####Input Channels

  1. input(0) - Input to filter

####Output Channels

  1. output(0) - Output to filter

####Parameters

  1. Frequency 1 (Hz) - Cutoff frequency 1 as fraction of pi, used for lowpass/highpass filters
  2. Frequency 2 (Hz) - Cutoff frequency as fraction of pi, NOT used for lowpass/highpass filters (i.e., bandpass/bandstop/etc.)
  3. Chebyshev (dB) - Attenuation parameter for Chebyshev windows
  4. Kaiser Alpha - Attenuation parameter for Kaiser window

####States

  1. Time (s)

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 98.5%
  • Makefile 1.5%