首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >离散傅里叶变换的傅里叶级数

离散傅里叶变换的傅里叶级数
EN

Stack Overflow用户
提问于 2011-04-30 10:08:25
回答 2查看 3.3K关注 0票数 3

我正在尝试从离散傅立叶变换重建一个函数。在Matlab中,它是这样完成的:

代码语言:javascript
复制
function [y] = Fourier(dft,x)
n = length(dft);
y = cos(pi*(x+1)'*(0:n-1))*real(dft)+sin(pi*(x+1)'*(0:n-1))*imag(dft)
end

我在Python中的尝试失败了,因为我不知道如何正确地将所有系数相加

代码语言:javascript
复制
def reconstruct(dft, x):
n = len(dft)
y = ([(coeff.real)*np.cos(np.pi*x*nn) + (coeff.imag)*np.cos(np.pi*x*nn) for coeff in dft for nn in range(0,n)])

但这是不正确的,因为我需要对n求和,然后将这些和加在一起。我说到哪了?

我尝试重新创建的方程式如下:

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-04-30 10:12:49

您运行的是两个嵌套循环,而不是一个。试试这个:

代码语言:javascript
复制
y = ([(dft[nn].real)*np.cos(np.pi*x*nn) + (dft[nn].imag)*np.cos(np.pi*x*nn) for nn in range(0,n)])
票数 5
EN

Stack Overflow用户

发布于 2011-05-01 04:21:28

实际上,您根本不应该使用Python循环。如果您向量化表达式,您将获得更好的可读性和更高效的代码。假设dft是一个复数值NumPy数组,您可以使用

代码语言:javascript
复制
xn = x * np.arange(n)
y = dft.real * np.cos(xn) + dft.imag * np.sin(xn)

(请注意,您的Matlab代码、Python代码和您给出的公式做了三件不同的事情。我给出的代码最接近Matlab代码。)

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5838994

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档