plot command is not work in Gauss Seidel Method
    7 Ansichten (letzte 30 Tage)
  
       Ältere Kommentare anzeigen
    
    suketu vaidya
 am 4 Dez. 2020
  
    
    
    
    
    Beantwortet: suketu vaidya
 am 4 Dez. 2020
            A = [ 
    1 0 -1 0 0 0 0
    -1 1 1 0 0 0 0
    0 -1 2 -1 0 0 0
    0 -1 0 2 0 1 0
    0 -1 -1 0 2 1 1
    0 0 1 -1 0 2 -1  
    0 0 0 -1 1 -1 2
];
b = [0 0 0 0 0 20 0]';
  x=[1 1 1 1 1 1 1];
n=size(x,1);
normVal=Inf; 
tol=1e-5; itr=0;
%%Gauss Seidel Method
while normVal>tol
    x_old=x;
    for i=1:n
        sigma=0;
        for j=1:i-1
                sigma=sigma+A(i,j)*x(j);
        end
        for j=i+1:n
                sigma=sigma+A(i,j)*x_old(j);
        end
        x(i)=(1/A(i,i))*(b(i)-sigma);
    end
    itr=itr+1;
    normVal=norm(x_old-x);
end
%%
fprintf('system solution : \n%f\n%f\n%f\n%f in %d iterations',x,itr);
 hold on
 plot(itr,x, '+')
 xlim([0 10])
ylim([0 2])
 hold off
end
0 Kommentare
Akzeptierte Antwort
  John D'Errico
      
      
 am 4 Dez. 2020
        When you tell us that something does not work, you need ot explain why you THINK it does not work. In fact, plot worked perfectly well there. At least, it tiried to work as well as it could.
itr
itr =
     2
x
x =
     0     1     1     1     1     1     1
plot(itr,x, '+')
So itr is the number 2. x is a vector. What did you expect it to do?
2 Kommentare
Weitere Antworten (1)
Siehe auch
Kategorien
				Mehr zu Linear Algebra finden Sie in Help Center und File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!