9

我正在尝试将 Matlab 代码转换为 Python。我想fdesign.lowpass()用 Python 实现 Matlab。使用以下 Matlab 代码的确切替代品是什么scipy.signal.firwin()

demod_1_a = mod_noisy * 2.*cos(2*pi*Fc*t+phi);
d = fdesign.lowpass('N,Fc', 10, 40, 1600);
Hd = design(d);
y = filter(Hd, demod_1_a);
4

1 回答 1

6

一个非常基本的方法是调用

# spell out the args that were passed to the Matlab function
N = 10
Fc = 40
Fs = 1600
# provide them to firwin
h = scipy.signal.firwin(numtaps=N, cutoff=40, nyq=Fs/2)
# 'x' is the time-series data you are filtering
y = scipy.signal.lfilter(h, 1.0, x)

这应该会产生一个类似于最终在 Matlab 代码中制作的过滤器。如果您的目标是获得功能等效的结果,这应该提供一个有用的过滤器。

但是,如果您的目标是 python 代码提供完全相同的结果,那么您将不得不查看design调用的底层(在 Matlab 中);从我的快速检查来看,解析 Matlab 调用以准确识别它在做什么,即使用什么设计方法等等,以及如何将其映射到相应的scipy调用中并不是一件容易的事。如果您真的想要兼容性,并且您只需要对有限数量的过滤器执行此操作,您可以手动查看该Hd.Numerator字段——这个数字数组直接对应于h上面 python 代码中的变量。因此,如果您将这些数字手动复制到一个数组中,您将获得数值等效的结果。

于 2013-07-26T15:09:33.430 回答