Main Content

Multirate Filtering in MATLAB and Simulink

Multirate filters are digital filters that change the sample rate of an sampled input signal. The process of rate conversion involves an upsampler, a downsampler, and a lowpass filter to process the signal.

The most basic multirate filters are interpolators, decimators, and noninteger sample rate converters. These filters are building components of more advanced filter technologies such as channelizers, channel synthesizers, two-channel filter banks, and Quadrature Mirror Filter (QMF). You can design these filters in MATLAB® and Simulink® using the designMultirateFIR function.

The designMultirateFIR function automatically designs an anti-aliasing FIR filter based on the rate conversion factor that you specify. The inputs to the designMultirateFIR function are the interpolation factor and the decimation factor. Optionally, you can provide the half-polyphase length or transition width and stopband attenuation. To design a decimator, set the interpolation factor to 1. Similarly, to design an interpolator, set the decimation factor to 1.

To implement the multirate filters in MATLAB, use the coefficients returned by the designMultirateFIR function as inputs to the dsp.FIRDecimator, dsp.FIRInterpolator, and dsp.FIRRateConverter System objects.

b = designMultirateFIR(1,4);
firDecim = dsp.FIRDecimator(4,b)
firDecim = 

  dsp.FIRDecimator with properties:

    DecimationFactor: 4
     NumeratorSource: 'Property'
           Numerator: [0 -2.2355e-05 -5.0269e-05 -5.2794e-05 0 1.0256e-04 1.9352e-04 … ]
           Structure: 'Direct form'

Alternatively, you can set the SystemObject flag of the designMultirateFIR function to true. The function designs and automatically creates the appropriate rate conversion object.

firDecim = designMultirateFIR(1,4,SystemObject=true)
firDecim = 

  dsp.FIRDecimator with properties:

    DecimationFactor: 4
     NumeratorSource: 'Property'
           Numerator: [0 -2.2355e-05 -5.0269e-05 -5.2794e-05 0 1.0256e-04 1.9352e-04 … ]
           Structure: 'Direct form'

In Simulink, compute these coefficients using the designMultirateFIR function in the default Auto mode of the FIR Decimation, FIR Interpolation, and FIR Rate Conversion blocks. You can also specify these coefficients as parameters or pass them through an input port.

These examples show how to implement an FIR decimator in MATLAB and Simulink. You can apply this workflow to an FIR interpolator and FIR rate converter as well.

Implement FIR Decimator in MATLAB

To implement an FIR Decimator, you must first design it by using the designMultirateFIR function. Specify the decimation factor of interest (usually greater than 1) and an interpolation factor equal to 1. You can use the default half-polyphase length of 12 and the default stopband attenuation of 80 dB. Alternatively, you can also specify the half-polyphase length, transition width, and stopband attenuation values.

Design an FIR decimator with the decimation factor set to 3 and the half-polyphase length set to 14. Use the default stopband attenuation of 80 dB.

b = designMultirateFIR(1,3,14);

Provide the coefficients vector b as an input to the dsp.FIRDecimator System object™. Visualize the magnitude response.

firDecim = dsp.FIRDecimator(3,b);
filterAnalyzer(firDecim)

Filter a noisy sine wave input using the firDecim object. The sine wave has frequencies at 1000 Hz and 3000 Hz. The noise is a white Gaussian noise with zero mean and a standard deviation of 1e-5. The decimated output will have one-third the sample rate as the input. Initialize two spectrumAnalyzer objects, one for the input and the other for the output.

f1 = 1000;
f2 = 3000;
Fs = 8000;
source = dsp.SineWave(Frequency=[f1,f2],SampleRate=Fs,...
    SamplesPerFrame=1026);

specanainput = spectrumAnalyzer(SampleRate=Fs,...
    PlotAsTwoSidedSpectrum=false,...
    Method='welch',...
    ShowLegend=true,YLimits=[-120 40],...
    Title='Noisy Input signal',...
    ChannelNames={'Noisy Input'});
specanaoutput = spectrumAnalyzer(SampleRate=Fs/3,...
    PlotAsTwoSidedSpectrum=false,...
    Method='welch',...
    ShowLegend=true,YLimits=[-120 40],...
    Title='Filtered output',...
    ChannelNames={'Filtered output'});

Stream the input and filter it in a processing loop.

for Iter = 1:1000
    input = sum(source(),2);
    noisyInput = input + (10^-5)*randn(1026,1);
    output = firDecim(noisyInput);
    specanainput(noisyInput)
    specanaoutput(output)
end

The input has two peaks: one at 1000 Hz and the other at 3000 Hz. The filter has a lowpass response with a passband frequency of 0.3π rad/sample. With a sample rate of 8000 Hz, that value is a passband frequency of 1200 Hz. The tone at 1000 Hz is unattenuated because it falls in the passband of the filter. The tone at 3000 Hz is filtered out.

Similarly, you can design an FIR interpolator and an FIR rate Converter by providing appropriate inputs to the designMultirateFIR function. To implement the filters, pass the designed coefficients to the dsp.FIRInterpolator and dsp.FIRRateConverter objects.

Implement an FIR Decimator in Simulink

You can design and implement the FIR multirate filters in Simulink™ using the FIR Decimation, FIR Interpolation, and FIR Rate Conversion blocks.

Open the model 'multiratefiltering.slx'.

The input signal is a noisy sinusoidal signal with two frequencies: one at 1000 Hz and the other at 3000 Hz. The sample rate of the signal is 8000 Hz and the Samples per frame parameter of the Sine Wave blocks is set to 1026. The noise added to the signal is a white Gaussian noise with zero mean and a variance of 1e-10.

The Coefficient source parameter of the FIR Decimation block is set to Dialog parameters, and the FIR filter coefficients parameter is set to designMultirateFIR(1,2). The function uses the default half-polyphase length of 12 and the default stopband attenuation of 80 dB. The magnitude response of the designed filter looks like as follows:

Run the model.

The first spectrum analyzer shows the spectrum of the original signal, while the second spectrum analyzer shows the spectrum of the decimated signal. Because the Rate options parameter in the FIR Decimation block is set to Allow multirate processing, the frame size of the signal is the same at the input and output of the FIR Decimation block, while the sample rate changes. For more details on this mode, see Rate Conversion by Frame-Rate Adjustment.

Sample Rate Conversion

Sample rate conversion is a process of converting the sample rate of a signal from one sampling rate to another sampling rate. Multistage filters minimize the amount of computation involved in sample rate conversion. To perform an efficient multistage rate conversion, use the dsp.SampleRateConverter object that:

  1. Accepts input sample rate and output sample rate as inputs.

  2. Partitions the design problem into optimal stages.

  3. Designs all the filters required by the various stages.

  4. Implements the design.

The design makes sure that aliasing does not occur in the intermediate steps.

In this example, change the sample rate of a noisy sine wave signal from an input rate of 192 kHz to an output rate of 44.1 kHz.

Initialize a sample rate converter object.

SRC = dsp.SampleRateConverter;

Display the filter information.

info(SRC)
ans = 
    'Overall Interpolation Factor    : 147
     Overall Decimation Factor       : 640
     Number of Filters               : 3
     Multiplications per Input Sample: 27.667188
     Number of Coefficients          : 8631
     Filters:                         
        Filter 1:
        dsp.FIRDecimator     - Decimation Factor   : 2 
        Filter 2:
        dsp.FIRDecimator     - Decimation Factor   : 2 
        Filter 3:
        dsp.FIRRateConverter - Interpolation Factor: 147
                             - Decimation Factor   : 160 
     '

SRC is a three-stage filter: two FIR decimators followed by an FIR rate converter.

Initialize the sine wave source. The sine wave has two tones: one at 2000 Hz and the other at 5000 Hz.

source = dsp.SineWave (Frequency=[2000 5000],SampleRate=192000,...
    SamplesPerFrame=1280);

Initialize two spectrum analyzers, one to see the spectrum of the input signal and the other to see the spectrum of the rate converted output signal. The 'PlotAsTwoSidedSpectrum' property of the spectrumAnalyzer objects is set to 'false', indicating that the spectrum shown is one-sided in the range [0 Fs/2], where Fs is the sample rate of the signal.

Fsin = SRC.InputSampleRate;
Fsout = SRC.OutputSampleRate;
specanainput = spectrumAnalyzer(SampleRate=Fsin,...
    PlotAsTwoSidedSpectrum=false,...
    Method='welch',...
    ShowLegend=true,YLimits=[-120 50],...
    Title='Input signal',...
    ChannelNames={'Input'});
specanaoutput = spectrumAnalyzer(SampleRate=Fsout,...
    PlotAsTwoSidedSpectrum=false,...
    Method='welch',...
    ShowLegend=true,YLimits=[-120 50],...
    Title='Rate Converted output',...
    ChannelNames={'Rate Converted output'});

Stream the input signal and convert the sample rate of the signal using the sample rate converter. View the spectra of both the input and output signals in the two spectrum analyzers.

The spectrum analyzers show the spectrum in the range [0 Fs/2]. For the spectrum analyzer showing the input, Fs/2 is 192000/2. For the spectrum analyzer showing the output, Fs/2 is 44100/2. Hence, the sample rate of the signal changes from 192 kHz to 44.1 kHz.

for Iter = 1:10000
    input = sum(source(),2);
    noisyinput = input + (10^-5)*randn(1280,1);
    output = SRC(noisyinput);
    specanainput(noisyinput);
    specanaoutput(output);
end

References

[1] Harris, Fred. Multirate Signal Processing for Communication Systems. Prentice Hall PTR, 2004.

Related Topics

Go to top of page