Ich habe versucht die finite Differenzenmethode in MATLAB zu lösen. Dabei ist mir aufgefallen, dass die Randbereiche nicht korrekt im Einheitsquadrat (0<x<1, 0<y<1) dargestellt werden und das die Funktion F(x,y) sich über die Auflösungsgröße verändert, was ja eigentlich nicht sein sollte.
I = eye(n-1)*(-1); %negierte Einheitsmatrix erstellen
B = zeros(n-1); %Nullmatrix B erstellen
for i = 1: n-1 %Die zu betrachtende Punkte mit einer 4 ausfüllen
B(i,i) = 4;
end
A = zeros((n-1)^2); %Nullmatrix A mit ((n-1)*(n-1))^2 Einträgen erstellen
for i=0 : (n-2) %Die Diagonale von A mit B ausfüllen
A(i*(n-1)+1:(i+1)*(n-1),i*(n-1)+1:(i+1)*(n-1))=B;
end
for i=0 : (n-2)-1 %Rechts neben der Diagonalmatrix mit I (Einheitsmatrix) ausfüllen
A(i*(n-1)+1:(i+1)*(n-1),(i+1)*(n-1)+1:(i+2)*(n-1))=I;
end
for i=0 : (n-2)-1 %Links neben der Diagonalmatrix mit I (Einheitsmatrix) ausfüllen
A((i+1)*(n-1)+1:(i+2)*(n-1),i*(n-1)+1:(i+1)*(n-1))=I;
end
for i=1 : ((n-1)^2)-1 %-1 links und rechts der Hauptdiagonalen eintragen
A(i,i+1) = -1;
A(i+1,i) = -1;
end
Koeffizientenmatrix = A;
%%%%%% Zuordnung eines Vektors in eine Matrix%%%%%% function F = MatrixF (U, n, h) tic %Zeit messen
%idxmat = reshape(uint64(U), n-1, n-1); %geringere Speicherkapazität
idxmat = reshape(U, n-1, n-1); %höhere Speicherkapazität
Randli = [1:-h:0]'; %RB links in Matrix einbauen
Randre = [0:h:1]'; %RB rechts in Matrix einbauen
Randun = [0+h:h:1-h];%RB unten in Matrix einbauen
Randob = [1-h:-h:0+h];%RB oben in Matrix einbauen
T = [Randob;idxmat;Randun];%Zusammenstellen von Matrix U und RBoben RBunten
F = [Randli T Randre];%Zusammenstellen aller RB und U
xyaxis= [0:h:1];%Skalierung
contour3 (xyaxis, xyaxis, F);%Grafische Darstellung
toc %Zeit messen
save('Probe.mat') %Konventieren von .m Datei in .mat %Dateiname muss angepasst werden
S = whos('-file','Probe.mat'); %Dateiname muss angepasst werden
for k = 1:length(S) disp(['' S(k).name...
'' mat2str(S(k).size)...
'' S(k).class]);
end end
%% Funktionsparameter definieren
maxit = 1000;
x = zeros((n-1)*(n-1),1);
%x = rand((n-1)*(n-1),1);
tol = 1e-5;
%% Erstellung der x-Werte (Jacobi-Verfahren)
%dx=zeros((n-1)*(n-1),1);
for i=1:maxit
summe=0;
for k=1:(n-1)*(n-1)
dx(k)=b(k);
for j=1:(n-1)*(n-1)
dx(k)=dx(k)-A(k,j)*x(j);
end
dx(k)=dx(k)/A(k,k);
x(k)=x(k)+dx(k);
if(dx(k) <= 0)
summe = summe - dx(k);
else
summe = summe + dx(k);
end end if(summe <= tol) break end end
%% Ausgabe des Vektors x als Funktionswert VektorU
VektorU=x;
end
ich denke, dass das Bild so aussehen sollte. Stattdessen liefert das Programm dieses Bild
Kann jemand mir sagen, wo der Fehler ist?
Vielen Dank
Einstellungen und Berechtigungen
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.