matlab - 如何使用 MATLAB 正确进行频率带通滤波器?
问题描述
我对 matlab 和信号处理还很陌生,但我正在做一个项目,但我被卡住了。我的目标是做一个带通快速傅里叶变换 (FFT) 滤波器,其截止频率为真实信号的 0.5 Hz 和 3 Hz。我的输入信号是一个 405Hz 采样的信号,大约有 35000 个样本。我的实现如下所示:
%ZFiltered = My signal
filtered = bandpass(fft(zFiltered), [0.5 3], sampling_frequency);
res = ifft(filtered);
subplot(2,1,1)
plot(zFiltered)
subplot(2,1,2)
plot(abs(res))
我的问题是:为什么我会得到一个包含虚部的信号?为什么会这样?
解决方案
我不清楚你的目标;这是您的问题暗示的三种不同方法
方法一bandpass
:用函数过滤
参考bandpass
文档,您将使用原始信号并指定滤波器频带和采样频率,如下所示:
filtered_signal = bandpass(zFiltered,[freq_low freq_high],sample_freq);
plot(zFiltered); hold on;
plot(filtered_signal);
其中输入是
zFiltered
:原始(未过滤的信号)freq_low=0.5
:带通范围的最低频率(Hz)`freq_high=3
:带通范围的最高频率(Hz)sample_freq=405
: 以赫兹为单位的采样频率
您使用数字快速傅立叶变换函数的方法fft
会产生复杂的结果,因为您正在查看由变换计算的实际分量(根据定义,这些分量具有实部和虚部)。您可以使用以下方法计算信号的功率:
P = abs(res/n).^2;
它为您提供了傅里叶变换中表示的每个频率的信号功率(有关更多信息,请参见此处fft
的函数文档)。
方法2fft
ifft
:用函数过滤
使用傅里叶变换和傅里叶逆变换功能对信号进行滤波。这里的步骤是用来fft
让信号进入频域。将要过滤的元素设置为零,然后应用傅里叶逆变换 ( ifft
) 以获得过滤后的信号。每个分量代表一个给定的离散频率,范围在 0Hz 和F_s/2
对信号有贡献的范围内。将要抑制的 FFT 组件设置为 zoro 并应用ifft
以获取滤波器信号。有关这些函数的信息以及在频域中处理信号的一些复杂性,请参阅fft
文档和ifft
文档。
方法 3:使用标准差分方程的系数进行过滤
计算数字带通滤波器的系数。这种方法计算标准差分方程的系数(向量A
和)(详见文档)。执行此操作的函数的一个示例是给出表示给定频率的巴特沃斯滤波器的系数。您还可以查看该功能以获取更多选项。B
filter
butter
designfilt
推荐阅读
- android - 如何更改 Android Project 中的所有文本文件?
- python - ET 中的评论:不仅仅是评论标签
- python - Python rarfile 包:BadRarFile
- arrays - Dictionary(grouping: , by: ) - 作为变量传递的谓词闭包
- python - 基于值的彩色条形图
- symfony - symfony liip 想象水印不工作
- mongodb - 使用 insertMany 命令恢复 bson 文档
- javascript - 是否可以使用 sequelize 在迁移中更新 postgresql 数据库中的现有数据
- vscode-settings - 如何隐藏在 Vs-code 中编译“c”或“c++”语言代码后生成的没有扩展名的文件
- c# - sql select语句在asp.net中返回空引用错误