ich habe versucht die diskrete Kosinus Transformation mit Matlab nachzuprogrammieren ohne die dct2/dct Funktion von Matlab zu nutzen.
Allerdings kommt da nur Müll raus ...
Vielleicht könnt ihr mir helfen den Fehler zu finden
[ky, kx] = size(Matrix);
kx = kx / M;
ky = ky / M;
B = cell(ky,kx);
for i = 1:1:ky
for j = 1:1:kx
B{i,j} = zeros(M,M);
B{i,j} = Matrix(((i-1)*M+1):((i-1)*M+M),((j-1)*M+1):((j-1)*M+M));
end;
end;
A = B;
B = cell(ky,kx);
for v = 1:1:ky
for u = 1:1:kx
Z = zeros(N,M);
for n = 0:1:(N-1) for m = 0:1:(M-1)
X = Matrix{v,u};
Z(n+1,m+1) = (c(n)*c(m)*2/M)*dctsum(N,M,n,m,X(n+1,m+1));
end end
B{v,u} = Z;
end end
A=B;
Edit:
Und hier die zu verwendene Transformationsgleichung:
Leider ist das Ergebnis falsch
Das Bild was bei meinem Quelltext herausgekommen ist, ist als Bild angehängt als DCT.jpg und das Originalbild ist hier:
[Img]http://isgwww.cs.uni-magdeburg.de/bv/gbv/uebung/pics/haus.bmp[/Img]
Danke schonmal im Vorraus für Lösungsansätze und Hinweise
Edit2:
ok, Problem hat sich geklärt, hab den Fehler gefunden und Programm funktioniert jetzt wunderbar ^^
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.