Signal Processing Toolbox | ![]() ![]() |
表示
[h,w]= freqz(b,a,n) h = freqz(b,a,w) [h,w] = freqz(b,a,n,'whole') [h,w,units] = freqz(b,a,...) [h,f] = freqz(b,a,n,fs) h = freqz(b,a,f,fs) [h,f] = freqz(b,a,n,'whole',fs) [h,f,units] = freqz(b,a,n,'whole',fs) freqz(b,a,...)
詳細
[h,w] = freqz(b,a,n)
は、ベクトルa
とb
で各々表されている(実数または複素数)分子と分母の多項式で決定されるディジタルフィルタの伝達関数から周波数応答ベクトル h
と対応する周波数ベクトル w
を出力します。ベクトルh
とw
は、共に長さn
です。周波数ベクトルw
は、0から ラデアン/サンプルの範囲の値です。整数
n
を設定していない場合、または、空ベクトルを設定していない場合、周波数応答は、デフォルトの512サンプルを使って計算します。
h = freqz(b,a,w)
は、ベクトルw
で設定した(ラデアン/サンプル)周波数で計算された周波数応答ベクトルh
を出力します。ベクトルw
は、任意の長さに設定できます。
[h,w] = freqz(b,a,n,'whole')
は、周波数応答を計算するために、単位円全体をn
個の等間隔で分割したものを使います。周波数ベクトルw
は、長さn
をもち、0から2ラデアン/サンプルの範囲内の値を取ります。
[h,w,units] = freqz(b,a,...)
は、周波数ベクトル w
に設定した単位をオプション文字引数units
に出力します。units
に出力される文字列は、'rad/sample'
で、ラデアン/サンプルを意味しています。
[h,f] = freqz(b,a,n,fs)
は、ディジタルフィルタの伝達関数が、ベクトルb
とa
で表される(実数または複素数)分子多項式と分母多項式であるものに対する周波数応答ベクトルh
と対応する周波数ベクトルf
を出力します。ベクトルh
とf
は共に長さn
です。この書式で、周波数応答は、スカラfs
で指定されるサンプル周波数(単位は Hz)を使って、計算されます。周波数ベクトルf
は、ヘルツ単位で、0からfs/2
Hzの範囲の値を取ります。
h = freqz(b,a,f,fs)
は、ベクトルf
で設定された周波数(Hz単位)で周波数応答ベクトルh
を計算します。ベクトルf
は、任意の長さを取ることができます。
[h,f] = freqz(b,a,n,'whole',fs)
は、周波数応答を計算するために単位円全体をn
等分した点を使います。周波数ベクトルf
は、0からfs
Hzの範囲の値をもつn
の長さです。
[h,f,units] = freqz(b,a,n,'whole',fs)
は、周波数ベクトルfを設定している単位をオプションの文字引数units
に出力します。units
に出力される文字列は、'Hz'
で、ヘルツを意味しています。
freqz(b,a,...)
は、フィルタの周波数応答の大きさと連続性をもたせた位相をプロットします。プロットは、カレントフィギュアウインドウ内に表示されます。
例題
b =
fir1(80,0.5,kaiser(81,8));
freqz(b,1);
注意
freqz
は、周波数応答を計算するためにFFTアルゴリズムを使っているので、3番目の引数を2のベキ乗数を設定することをお勧めします。詳細は、fft
のリファレンスを参照してください。
アルゴリズム
デジタルフィルタの周波数応答[1]は、z = ejで計算した伝達関数として内挿されます。つぎの型で有理伝達関数を常に書き表します。
freqz
は、ユーザが設定した(実数または複素数)分子多項式や分母多項式から伝達関数を決定します。そして、デジタルフィルタの複素数周波数応答H(ej) を出力します。周波数応答は、ユーザが使用した書式で決定したサンプル点で計算します。
freqz
は、入力引数として周波数ベクトルを設定しない場合、FFTアルゴリズムを使って、周波数応答を計算します。これは、伝達関数の分子係数と分母係数の比として、周波数応答を計算します。分子係数と分母係数の長さが、希望する長さになるように(2のベキ乗数)ゼロを付加します。
周波数ベクトルを入力引数として設定すると、freqz
は、参考文献[1]に記述している入れ子になった多項式計算のHorner法を使って、各周波数点で多項式を計算し、分子の応答を分母の応答で割り算します。
参考
|
絶対値(ゲイン) |
|
位相角 |
|
1次元高速フーリエ変換 |
|
巡回型(IIR)または非巡回型(FIR)フィルタによるデータのフィルタリング |
|
アナログフィルタの周波数応答 |
|
ディジタルフィルタの周波数応答をプロット |
|
ディジタルフィルタのインパルス応答 |
|
周波数データから離散系フィルタの同定 |
|
対数等間隔ベクトルの生成(MATLAB Function Referenceを参照) |
参考文献
[1] Oppenheim, A.V., and R.W. Schafer, Discrete-Time Signal Processing, Prentice-Hall, 1989, pp. 203-205.
![]() | freqspace | freqzplot | ![]() |