[英]How can I get same results for fft2() in MATLAB and Python?
I am translating a MATLAB code to Python code but I get different results from numpy fft2()
and MATLAB fft2()
. 差別不小。 我怎樣才能得到相同的結果?
其中S
是(10,10,3)
數組
在 Python 中:
Normin1 = fft2(S)
print("Normin is\n",Normin1[:,:,0])
Output(Just first row):
Normin is
[[ 1.29098039e+01+0.00000000e+00j
-8.14368936e-01-4.02146547e-01j
4.57184468e-01+4.59545965e-01j
2.37898348e-01-1.58643666e-01j
-6.89491738e-02+1.65467814e-01j
3.29411765e-01-1.38777878e-17j
-6.89491738e-02-1.65467814e-01j
2.37898348e-01+1.58643666e-01j
4.57184468e-01-4.59545965e-01j
-8.14368936e-01+4.02146547e-01j]
但在 MATLAB 中:
Normin1 = fft2(S);
Output of first row
44.27451 + 0.00000i
-1.04275 - 3.36765i
0.72446 - 1.92128i
0.02706 + 0.09694i
0.70692 + 0.28154i
-0.90980 + 0.00000i
0.70692 - 0.28154i
0.02706 - 0.09694i
0.72446 + 1.92128i
-1.04275 + 3.36765i
我解決了我的問題。 Python 按行執行數組操作。 相反,Matlab/Octave 按列進行數組操作。 這就是為什么,它應該如下得到相同的結果,
MATLAB 代碼:
Normin1 = fft2(S);
Python 等效:
Normin1 = np.fft2(S.T).T
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.