Я уже много искал в интернете, но до сих пор не нашел решения. Что я хочу, чтобы преобразовать Matlab’s ifft2
функция в OpenCV, чтобы получить тот же результат. Например, если у меня есть 10x10
матрица A
как:
A =
11 22 33 1 1 1 1 1 1 1
44 55 66 1 1 1 1 1 1 1
77 88 99 1 1 1 1 1 1 1
100 111 122 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
Затем в Matlab, позвонив ifft2(A)
дает мне это:
ans =
9.1600 + 0.0000i 5.4570 + 4.6041i 0.5640 + 4.4443i -1.1170 + 0.7295i 1.0560 - 1.4066i 2.7200 + 0.0000i 1.0560 + 1.4066i -1.1170 - 0.7295i 0.5640 - 4.4443i 5.4570 - 4.6041i
1.7274 + 6.5730i -2.5500 + 5.5266i -3.6046 + 1.6030i -1.0629 - 0.6619i 1.2068 + 0.5078i 0.5758 + 2.1910i -0.9060 + 1.3047i 0.2070 - 0.8463i 3.4605 - 0.4030i 4.7141 + 3.3760i
-3.6507 + 1.1351i -3.2357 - 1.1758i -1.1907 - 1.8927i 0.1292 - 0.6560i -0.3480 + 0.5913i -1.2169 + 0.3784i -0.8219 - 0.3575i 0.2811 + 0.1882i 0.0968 + 1.8925i -1.8722 + 2.6341i
0.6876 - 1.9331i 1.4480 - 0.9227i 0.9832 + 0.1199i 0.0550 + 0.1593i -0.1955 - 0.4607i 0.2292 - 0.6444i 0.3196 - 0.1496i -0.3841 + 0.0821i -1.0290 - 0.6749i -0.5821 - 1.7727i
1.1457 + 1.6084i -0.1392 + 1.7632i -0.8331 + 0.7911i -0.3628 - 0.0938i 0.3857 + 0.0000i 0.3819 + 0.5361i -0.1268 + 0.4468i -0.0493 - 0.2667i 0.8930 - 0.4889i 1.6339 + 0.4186i
-1.6800 + 0.0000i -1.1861 - 0.8618i -0.2800 - 0.8618i 0.0661 - 0.2034i -0.2800 + 0.2034i -0.5600 + 0.0000i -0.2800 - 0.2034i 0.0661 + 0.2034i -0.2800 + 0.8618i -1.1861 + 0.8618i
1.1457 - 1.6084i 1.6339 - 0.4186i 0.8930 + 0.4889i -0.0493 + 0.2667i -0.1268 - 0.4468i 0.3819 - 0.5361i 0.3857 - 0.0000i -0.3628 + 0.0938i -0.8331 - 0.7911i -0.1392 - 1.7632i
0.6876 + 1.9331i -0.5821 + 1.7727i -1.0290 + 0.6749i -0.3841 - 0.0821i 0.3196 + 0.1496i 0.2292 + 0.6444i -0.1955 + 0.4607i 0.0550 - 0.1593i 0.9832 - 0.1199i 1.4480 + 0.9227i
-3.6507 - 1.1351i -1.8722 - 2.6341i 0.0968 - 1.8925i 0.2811 - 0.1882i -0.8219 + 0.3575i -1.2169 - 0.3784i -0.3480 - 0.5913i 0.1292 + 0.6560i -1.1907 + 1.8927i -3.2357 + 1.1758i
1.7274 - 6.5730i 4.7141 - 3.3760i 3.4605 + 0.4030i 0.2070 + 0.8463i -0.9060 - 1.3047i 0.5758 - 2.1910i 1.2068 - 0.5078i -1.0629 + 0.6619i -3.6046 - 1.6030i -2.5500 - 5.5266i
В OpenCV я написал следующий код (спасибо интернету) и действительно добился того же результата как у Матлаба.
cv::Mat inverseDFT;
cv::Mat planes[] = { cv::Mat_<float>(input), cv::Mat::zeros(input.size(), CV_32F) };
cv::Mat complex;
cv::merge(planes, 2, complex);
cv::idft(complex, inverseDFT, cv::DFT_SCALE | cv::DFT_INVERSE);
Пока это хорошо. Но, когда я использую другую матрицу размера 82x82
из тот же тип и значение, результат Matlab очень отличается от результата OpenCV. Это вывод Matlab (первые две строки):
1.0e+05 *
[-0.0000 -9.6761 -4.6365 1.8979 1.4972 -0.0025 0.1037 -0.0919 0.3140 0.0032 0.0195 0.0057 -0.0002 0.0147 -0.0023 0.0088 0.0045 -0.0023 0.0135;
-0.6180 4.6026 1.9042 -1.0747 -0.5034 -0.0088 -0.0466 0.0479 -0.1339 -0.0019 -0.0078 -0.0019 -0.0031 -0.0098 0.0009 -0.0038 -0.0053 0.0034 -0.0070;
....]
И это результат OpenCV (первые две строки):
[15.8347 148.3 15.5297 148.068 15.3074 147.476 15.1266 146.854 14.9336 146.121 14.649 145.361 14.4584 144.357 14.1337 143.344 13.8938 142.052 13.4711 140.892 12.9521 139.762 12.3772 138.7 11.7153 137.773 11.149 136.736 10.6333 136.07 10.0025 135.68 9.35163 135.744 8.37026 136.085 7.51313 136.597 6.65663 137.297 5.84039 138.144 5.08981 138.964 4.2696 139.838 3.93125 140.847 3.83195 141.894 4.0224 142.883 4.54194 143.872 5.35709 144.933 6.18112 145.637 6.97564 146.306 7.91474 146.833 8.90979 147.268 9.90416 147.69 10.7855 147.929 11.9145 148.177 13.3188 148.587 14.5545 148.747 15.3029 148.96 15.8501 149.022 16.1713 149.002 16.0789 148.678 ;
83.1579 -72.1501 83.2033 -72.3991 83.0443 -72.9689 83.028 -73.201 82.9732 -73.2787 82.9527 -73.2777 83.039 -73.2688 83.2974 -73.331 83.7781 -73.6298 84.5012 -73.8774 85.2545 -74.02 86.2663 -74.1823 87.4866 -74.3593 88.8467 -74.474 90.3635 -74.5438 91.6828 -74.5036 92.9061 -73.9815 93.1934 -73.0743 93.4254 -72.1992 93.1917 -71.2198 92.45 -70.201 91.1874 -69.4783 89.0805 -68.5612 87.2752 -67.461 85.2434 -66.3476 83.1033 -65.316 80.9829 -64.4404 79.0108 -63.7758 77.3056 -63.3485 75.7612 -63.1322 74.7189 -63.3549 74.1633 -63.9313 74.1057 -64.8886 74.2431 -66.0125 74.9995 -66.9026 76.9265 -67.4861 78.861 -68.5714 80.1996 -69.2898 81.3412 -70.1617 82.2211 -70.9372 82.7735 -71.4485;
....]
Что вызвало эту разницу? Может ли кто-нибудь помочь? Благодарю.
На самом деле FFT в Matlab является дискретным преобразованием Фурье,
Я обнаружил, что тот же результат может быть достигнут через OpenCV DCT