Main Content

このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。

dsp.LowpassFilter

FIR または IIR ローパス フィルター

説明

dsp.LowpassFilter オブジェクトは、指定された設計仕様を使用して、経時的に入力の各チャネルを個別にフィルター処理します。FilterType プロパティを 'FIR' または 'IIR' に設定することで、オブジェクトを FIR または IIR ローパス フィルターとして実装できます。

FilterType プロパティが 'FIR' に設定されている場合、このオブジェクトは、dsp.FIRFilter と関数 firceqrip および関数 firgr を使用するための代替として使用できます。dsp.LowpassFilter オブジェクトは 2 つの手順からなるプロセスを 1 つに凝縮します。measure を使用して、設計が指定の仕様を満たすことを確認できます。

入力の各チャネルをフィルター処理するには、次を行います。

  1. dsp.LowpassFilter オブジェクトを作成し、そのプロパティを設定します。

  2. 関数と同様に、引数を指定してオブジェクトを呼び出します。

System object の機能の詳細については、System object とはを参照してください。

このオブジェクトは、特定の条件下で C/C++ コード生成と SIMD コード生成をサポートします。このオブジェクトは、ARM® Cortex®-M プロセッサおよび ARM Cortex-A プロセッサ用のコード生成もサポートします。詳細については、コード生成を参照してください。

作成

説明

LPF = dsp.LowpassFilter は、既定のフィルター設定を使用して、最小次数の FIR ローパス フィルターを返します。既定のプロパティ設定を使用してこのオブジェクトを呼び出すと、通過帯域周波数 8 kHz、阻止周波数帯域 12 kHz、通過帯域リップル 0.1 dB、阻止帯域の減衰量 80 dB を基準に入力データがフィルター処理されます。

LPF = dsp.LowpassFilter(Name=Value) は、1 つ以上の Name-Value ペアの引数で指定された追加のプロパティをもつローパス フィルターを返します。Name はプロパティ名で、Value は対応する値です。たとえば、PassbandFrequency=8000 は、フィルターの通過帯域の周波数仕様を 8000 Hz に設定します。

プロパティ

すべて展開する

特に指定がない限り、プロパティは "調整不可能" です。つまり、オブジェクトの呼び出し後に値を変更することはできません。オブジェクトは呼び出すとロックされ、ロックを解除するには関数 release を使用します。

プロパティが "調整可能" の場合、その値をいつでも変更できます。

プロパティ値の変更の詳細については、System object を使用した MATLAB でのシステム設計を参照してください。

フィルター応答のタイプ。次のオプションのいずれかとして指定します。

  • 'FIR' — このオブジェクトは FIR ローパス フィルターを設計します。

  • 'IIR' — このオブジェクトは IIR ローパス (双二次) フィルターを設計します。

最小次数フィルターを設計するためのフラグ。次として指定します。

  • true –– オブジェクトは、フィルター設計仕様を満たす最小次数のフィルターを設計します。

  • false –– オブジェクトは、FilterOrder プロパティで指定された次数でフィルターを設計します。

FIR または IIR フィルターの次数。正の整数として指定します。

依存関係

このプロパティを有効にするには、DesignForMinimumOrderfalse に設定します。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

フィルター通過帯域エッジ周波数。正の実数のスカラー (Hz 単位または正規化周波数単位 (R2023a 以降)) として指定します。

NormalizedFrequency プロパティを次のように設定した場合:

  • false –– 通過帯域エッジ周波数の値は Hz 単位であり、阻止帯域周波数未満かつ SampleRate プロパティ値の半分未満でなければなりません。

  • true –– 通過帯域エッジ周波数の値は正規化周波数単位です。値は、1.0 未満の正のスカラーでなければなりません。

(R2023a 以降)

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

フィルター阻止帯域エッジ周波数。正の実数のスカラー (Hz 単位または正規化周波数単位 (R2023a 以降)) として指定します。

NormalizedFrequency プロパティを次のように設定した場合:

  • false –– 阻止帯域エッジ周波数の値は Hz 単位です。値は、通過帯域エッジ周波数より大きく、SampleRate プロパティ値の半分未満でなければなりません。

  • true –– 阻止帯域エッジ周波数の値は正規化周波数単位です。値は、通過帯域エッジ周波数より大きく 1.0 未満の正のスカラーでなければなりません。

(R2023a 以降)

依存関係

このプロパティを有効にするには、DesignForMinimumOrder プロパティを true に設定します。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

通過帯域でのフィルター応答の最大リップル。正の実数のスカラー (dB 単位) として指定します。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

阻止帯域での最小減衰量。正の実数のスカラー (dB 単位) として指定します。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

R2023a 以降

正規化単位で周波数を設定するフラグ。次の値のいずれかとして指定します。

  • true –– 通過帯域エッジと阻止帯域エッジの周波数は、正規化周波数単位であり、1.0 未満でなければなりません。

  • false –– 通過帯域エッジと阻止帯域エッジの周波数は Hz 単位です。SampleRate プロパティで入力サンプル レートを指定できます。

データ型: logical

入力サンプル レート (Hz 単位)。実数の正のスカラーとして指定します。

依存関係

このプロパティを有効にするには、NormalizedFrequencyfalse に設定します。 (R2023a 以降)

データ型: single | double

固定小数点プロパティ

固定小数点演算出力の丸め手法。文字ベクトルとして指定します。丸め手法の詳細については、精度と範囲を参照してください。

係数の語長と小数部の長さ。numerictype オブジェクトとして指定します。可能な限り最高の精度になるよう、numerictype(1,16) は既定で、16 ビットの係数および係数の値に基づいて決定された小数部の長さをもつ符号付き数値型オブジェクトに対応します。

このプロパティを調整することはできません。

出力の語長は入力の語長と同じです。出力の小数部の長さは、出力のダイナミック レンジ全体をオーバーフローせずに表現できるように計算されます。出力の小数部の長さを計算する方法の詳細については、Fixed-Point Precision Rules for Avoiding Overflow in FIR Filtersを参照してください。

使用法

説明

y = LPF(x) ローパス フィルターは入力信号 x をフィルター処理します。y は、x にローパス フィルターを適用したバージョンです。

入力引数

すべて展開する

ノイズを含むデータ入力。ベクトルまたは行列として指定します。入力信号が行列の場合、行列の各列は独立したチャネルとして扱われます。入力信号の行数はチャネル長を表します。このオブジェクトは可変サイズの入力を受け入れます。オブジェクトがロックされると、各入力チャネルのサイズは変更できますが、チャネルの数は変更できません。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | fi
複素数のサポート: あり

出力引数

すべて展開する

フィルター処理された出力。ベクトルまたは行列として返されます。出力は入力と同じサイズ、データ型および実数/複素数の特性をもちます。

データ型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | fi
複素数のサポート: あり

オブジェクト関数

オブジェクト関数を使用するには、System object™ を最初の入力引数として指定します。たとえば、obj という名前の System object のシステム リソースを解放するには、次の構文を使用します。

release(obj)

すべて展開する

freqz離散時間フィルター System object の周波数応答
fvtoolDSP フィルターの周波数応答の可視化
impz離散時間フィルター System object のインパルス応答
infoInformation about filter System object
coeffsフィルター System object 係数を構造に返します。
costEstimate cost of implementing filter System object
grpdelay離散時間フィルター System object の群遅延応答
generatehdlGenerate HDL code for quantized DSP filter (requires Filter Design HDL Coder)
measureMeasure frequency response characteristics of filter System object
outputDelayDetermine output delay of single-rate or multirate filter
stepSystem object のアルゴリズムの実行
releaseリソースを解放し、System object のプロパティ値と入力特性の変更を可能にします。
resetSystem object の内部状態のリセット

すべて折りたたむ

44.1 kHz でサンプリングされるデータに対する、最小次数の FIR ローパス フィルターを作成します。8 kHz の通過帯域周波数、12 kHz の阻止帯域周波数、0.1 dB の通過帯域リップル、80 dB の阻止帯域の減衰量を指定します。

Fs = 44.1e3; 
filtertype = 'FIR';
Fpass = 8e3;
Fstop = 12e3; 
Rp = 0.1;
Astop = 80;
FIRLPF = dsp.LowpassFilter(SampleRate=Fs,...
                             FilterType=filtertype,...
                             PassbandFrequency=Fpass,...
                             StopbandFrequency=Fstop,...
                             PassbandRipple=Rp,...
                             StopbandAttenuation=Astop);

FIR ローパス フィルターと同じプロパティを設定した、最小次数の IIR ローパス フィルター設計します。クローンしたフィルターの FilterType プロパティを IIR に変更します。

IIRLPF = clone(FIRLPF);
IIRLPF.FilterType = 'IIR';

FIR ローパス フィルターのインパルス応答をプロットします。ゼロ次係数は、19 サンプル分遅延されます。これは、フィルターの群遅延と等価です。FIR ローパス フィルターは因果性 FIR フィルターです。

impz(FIRLPF)

IIR ローパス フィルターのインパルス応答をプロットします。

impz(IIRLPF)

FIR ローパス フィルターの振幅および位相応答をプロットします。

freqz(FIRLPF)

IIR ローパス フィルターの振幅および位相応答をプロットします。

freqz(IIRLPF)

FIR ローパス フィルターの実装コストを計算します。

cost(FIRLPF)
ans = struct with fields:
                  NumCoefficients: 39
                        NumStates: 38
    MultiplicationsPerInputSample: 39
          AdditionsPerInputSample: 38

IIR ローパス フィルターの実装コストを計算します。IIR フィルターのほうが FIR フィルターよりも効率的な実装になります。

cost(IIRLPF)
ans = struct with fields:
                  NumCoefficients: 18
                        NumStates: 14
    MultiplicationsPerInputSample: 18
          AdditionsPerInputSample: 14

FIR ローパス フィルターの群遅延を計算します。

grpdelay(FIRLPF)

IIR ローパス フィルターの群遅延を計算します。FIR フィルターの群遅延は一定 (線形位相) である一方、IIR の群遅延は一定ではありません。

grpdelay(IIRLPF)

dsp.LowpassFilter System object™ を使用してローパス フィルターを作成します。NormalizedFrequency プロパティを true に設定すると、正規化周波数単位の周波数仕様をもつフィルターが設計されます。

LPF = dsp.LowpassFilter(NormalizedFrequency=true)
LPF = 
  dsp.LowpassFilter with properties:

               FilterType: 'FIR'
    DesignForMinimumOrder: true
        PassbandFrequency: 0.3628
        StopbandFrequency: 0.5442
           PassbandRipple: 0.1000
      StopbandAttenuation: 80
      NormalizedFrequency: true

  Use get to show all properties

spectrumAnalyzer オブジェクトを作成して、入力信号と出力信号のスペクトルを可視化します。サンプル レートが 44.1e3 Hz の場合、フィルターの通過帯域周波数と阻止帯域周波数はそれぞれ 8000 Hz と 12000 Hz に変換されます。

SA = spectrumAnalyzer(SampleRate=44.1e3,...
                      PlotAsTwoSidedSpectrum=false,ShowLegend=true,...
                      YLimits=[-150 30],...
                      Title='Input Signal and Output Signal of Lowpass Filter');
SA.ChannelNames = {'Input','Output'};

ローパス フィルターのアルゴリズムを実行して、ホワイト ガウス ノイズ入力信号をフィルター処理します。スペクトル アナライザーを使用して、入力信号と出力信号を確認します。

for k = 1:100
    Input = randn(1024,1);
    
    Output = LPF(Input);
    
    SA([Input,Output]);
end

IIR ローパス フィルターを設定します。ホワイト ガウス ノイズのサンプリング レートは 44,100 Hz です。フィルターの通過帯域周波数は 8 kHz、阻止帯域周波数は 12 kHz、通過帯域リップルは 0.1 dB、阻止帯域の減衰量は 80 dB です。

Fs = 44.1e3;
filtertype = 'IIR';
Fpass = 8e3;
Fstop = 12e3;
Rp = 0.1;
Astop = 80;
LPF = dsp.LowpassFilter(SampleRate=Fs,...
                             FilterType=filtertype,...
                             PassbandFrequency=Fpass,...
                             StopbandFrequency=Fstop,...
                             PassbandRipple=Rp,...
                             StopbandAttenuation=Astop);

ローパス フィルターの振幅応答を確認します。

filterAnalyzer(LPF)

スペクトル アナライザー オブジェクトを作成します。

SA = spectrumAnalyzer(SampleRate=Fs,...
    PlotAsTwoSidedSpectrum=false,...
    ShowLegend=true,YLimits=[-150 30],...
    Title='Input Signal and Output Signal of IIR Lowpass Filter');
SA.ChannelNames = {'Input','Output'};

ホワイト ガウス ノイズ入力信号をフィルター処理します。スペクトル アナライザーを使用して、入力信号と出力信号を確認します。

for k = 1:100
    Input = randn(1024,1);

    Output = LPF(Input);

    SA([Input,Output]);
end

ローパス フィルターの周波数応答特性を測定します。既定のプロパティを使用して dsp.LowpassFilter System object を作成します。フィルターの周波数応答特性を測定します。

LPF = dsp.LowpassFilter
LPF = 
  dsp.LowpassFilter with properties:

               FilterType: 'FIR'
    DesignForMinimumOrder: true
        PassbandFrequency: 8000
        StopbandFrequency: 12000
           PassbandRipple: 0.1000
      StopbandAttenuation: 80
      NormalizedFrequency: false
               SampleRate: 44100

  Use get to show all properties

LPFMeas = measure(LPF)
LPFMeas = 
Sample Rate      : 44.1 kHz  
Passband Edge    : 8 kHz     
3-dB Point       : 9.1311 kHz
6-dB Point       : 9.5723 kHz
Stopband Edge    : 12 kHz    
Passband Ripple  : 0.08289 dB
Stopband Atten.  : 81.6141 dB
Transition Width : 4 kHz     
 

アルゴリズム

すべて展開する

参照

[1] Shpak, D.J., and A. Antoniou. "A generalized Remez method for the design of FIR digital filters." IEEE® Transactions on Circuits and Systems. Vol. 37, Issue 2, Feb. 1990, pp. 161–174.

[2] Selesnick, I.W., and C. S. Burrus. "Exchange algorithms that complement the Parks-McClellan algorithm for linear-phase FIR filter design." IEEE Transactions on Circuits and Systems. Vol. 44, Issue 2, Feb. 1997, pp. 137–143.

拡張機能

バージョン履歴

R2015a で導入

すべて展開する