⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 jacobi.m

📁 学习matlab的朋友
💻 M
字号:
function[x,many]=jacobi(A,b,x,tol)
% 雅可比迭代法用于计算线性方程组.
%   a为待解线形方程组的系数矩阵, b为常数矩阵,
%   x为一初始值, tol为计算精度

% 调用格式为:[x,many]=jacobi(A,b,x,tol) 
% x,tol 可省略
if nargin<=2 
    x=zeros(length(A),1);
    tol=1e-4; 
elseif nargin<=3
    tol=1e-4;    
end

D=diag(diag(A));
U=triu(-A,1);
L=tril(-A,-1);
hold on
for t=1:length(x)
    plot(t,x(t),'b^')
end
many=0;
while  true
  x0=x;  
  x=inv(D)*(U+L)*x+inv(D)*b;
  many=many+1;
  for t=1:length(x)
    plot(t,x(t),'bo')
  end
 
  if (norm(x0-x)<tol) && i<1000
      for t=1:length(x)
          plot(t,x(t),'r.')
      end
      break;
  end
end
  hold off

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -