gpt4 book ai didi

python - Python 中二维矩阵的傅里叶变换

转载 作者:行者123 更新时间:2023-12-01 06:24:34 26 4
gpt4 key购买 nike

所以,我有一个具有 72x72 值的矩阵,每个值对应于具有 72x72 位点的三角晶格上的一些能量。我正在尝试对这些值进行傅里叶变换,但我不明白如何使用 np.fft.fftn 来实现这一点。

为了说明我的问题,我编写了以下带有一些随机值的基本代码。三角形给出了晶格的 x,y 坐标。

import numpy as np
import matplotlib.pyplot as plt

def triangular(nsize):
x=0
y=0
X=np.zeros((nsize,nsize))
Y=np.zeros((nsize,nsize))
for i in range(nsize):
for j in range(nsize):
X[i,j]+=1/2*j+i
Y[i,j]+=np.sqrt(3)/2*j
return(X,Y)

xx = triangular(72)[0]
yy = triangular(72)[1]


plt.figure()
plt.pcolormesh(xx, yy, np.reshape(np.random.rand(72**2),(72,72)))

enter image description here

我没有使用随机数据,但我不想让示例变得那么复杂。事实上,当我现在使用以下 FFT 时,我每次都会看到相同的图:

matrix = []

matrix.append(triangular(72)[0])

matrix.append(triangular(72)[1])

matrix.append(np.reshape(np.random.rand(72**2),(72,72)))

spectrum_3d = np.fft.fftn(matrix) # Fourrier transform along x, y, energy

kx = np.linspace(-4*np.pi/3,4*np.pi/3,72) #this is the range I want to plot

ky = np.linspace(-2*np.pi/np.sqrt(3),2*np.pi/np.sqrt(3),72)



Ky, Kx = np.meshgrid(ky, kx, indexing='ij') #making a grid



plt.figure(figsize=(11,9))
psd = plt.pcolormesh(Kx, Ky, abs(spectrum_3d[2])**2)
cbar = plt.colorbar(psd)
plt.xlabel('kx')
plt.ylabel('ky')

enter image description here

我的结果看起来总是一样,但我不知道出了什么问题。另外,对于我的相关值来说,它们具有很大的对称性,绘图看起来是相同的。

最佳答案

由于直流电占主导地位,您无法“看到”频谱。

import numpy as np
import matplotlib.pyplot as p
%matplotlib inline

n=72
x=np.arange(n)
y=np.arange(n)
X,Y= np.meshgrid(x,y)

data=np.reshape(np.random.rand(n**2),(n,n))

data_wo_DC= data- np.mean(data)

spectrum = np.fft.fftshift(np.fft.fft2(data))
spectrum_wo_DC = np.fft.fftshift(np.fft.fft2(data_wo_DC))

freqx=np.fft.fftshift(np.fft.fftfreq(72,1)) #q(n, d=1.0)
freqy=np.fft.fftshift(np.fft.fftfreq(72,1))
fX,fY= np.meshgrid(freqx,freqy)


p.figure(figsize=(20,6))
p.subplot(131)
p.pcolormesh(X,Y, data)
p.colorbar()

p.subplot(132)
p.pcolormesh(fX,fY,np.abs(spectrum))
p.colorbar()
p.title('most data is in the DC')

p.subplot(133)
p.pcolormesh(fX,fY,np.abs(spectrum_wo_DC))
p.colorbar()
p.title('wo DC we can see the structure');

enter image description here

关于python - Python 中二维矩阵的傅里叶变换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60226373/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com