1次RCフィルターの時間離散バージョンを実現することにより、(デジタル)信号処理の知識を確実に理解しようとしています。(背景は、SDRの目的でソフトウェアにPLLを実装しようとしていることですが、これは別の話です...)
私の問題は、そのようなフィルターの差分方程式を作成する方法を理解し、その係数を導出する方法を理解したと思ったことです。ただし、freqz関数を使用してMATLABで応答をプロットすると、計算された係数a
とb
係数を使用して、RCフィルター応答のように見えるものが得られません。
このトピックに関するウィキペディアのページ(http://en.wikipedia.org/wiki/Low-pass_filter#Discrete-time_realization)を参照して、雑草が完全になくなっていないことを確認しましたが、それでもそうではありません。 tヘルプ。これにより、差分方程式が次のように詳細に示されます。
yi = alpha * xi + ( 1 - alpha ) * yi-1
where: alpha = sample period / ( RC + sample period )
例:
fs = 96000.0; % Sample rate.
delta_t = 1.0 / fs; % Sample period.
fc = 5000.0; % Filter cut off frequency.
tau = 1 / ( 2 * pi * fc ); % Time constant of filter.
alpha = delta_t / ( tau + delta_t ); % Smoothing factor per Wikipedia page.
b = [ alpha ]; % 'b' coefficients
a = [ 1.0, ( 1 - alpha ) ]; % 'a' coefficents
freqz( b, a, 1024, fs ); % 1024 point FFT used.
結果:
私がどこで間違っているのかについて何か考えはありますか?私は何かを完全に誤解しましたか?
前もって感謝します。