/ / use dft do przetwarzania obrazu w programie Matlab bez funkcji Matlab - Matlab, dft

użyj dft do przetwarzania obrazu w matlab bez funkcji matlab - matlab, dft

Mam 2 funkcje w programie Matlab

%%%%%%% test_dft
clc;clear all;close all;
%%


img=(imread("images/test_image.jpg"));
if isrgb(img)
a=double(rgb2gray(img));
else
a=double(img);
end
temp = zeros(size(a));
f = double(zeros(size(a)));
[m n]=size(a)
for i = 1:m
temp(:,i)=dft(a(:,i));
end
for j = 1:n
f(j,:) = dft(a(j,:));
end


%%%%%%%% dft.m
function X=dft(x1)
N=length(x1);
X=zeros(size(x1));
i=sqrt(-1);
for k=0:N-1
for n=0:N-1
X(k+1)=(X(k+1)+x1(n+1)*exp(-2*pi*i*k*n/N)) ;
end
end
end

Chcę obliczyć dft obrazu, a następnie użyć go do maskowania w dziedzinie częstotliwości (bez funkcji matlab). ten kod jest długi, ale nie działa. Nie wiem dlaczego.

Odpowiedzi:

0 dla odpowiedzi № 1

imread zwraca liczby całkowite. Przekonwertuj je, aby podwoiły się jako pierwsze.

a = double(a);