当前位置:   article > 正文

[MATLAB]Jacobi迭代_jacobi迭代法matlab

jacobi迭代法matlab

[MATLAB代码]关于使用雅可比迭代法求线性方程组的数值解

jacobi.m
%定义Jacobi迭代函数
function [x, n] = jacobi(A, b, x0, eps)
%计算迭代矩阵
D = diag(diag(A));
L = -tril(A,-1);
U = -triu(A,1);
BJ = D\(L+U);
f = D\b;
%判断收敛性
a = max(abs(eig(BJ)));
if a >= 1
    disp('Jacobi迭代不收敛');
    return             %不再向下执行
else
    n = 1;
    x = BJ*x0 + f;
    while norm(x-x0,inf)>=eps   %无穷范数
        x0 = x;
        x = BJ*x0+f;
        n = n+1;
    end
end

A = [4 3 0; 3 4 -1; 0 -1 4];
b = [24; 30; -24];
x0 = [0; 0; 0];
eps = 1.0e-6;
[x, n] = jacobi(A,b,x0,eps);

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/176833
推荐阅读
相关标签
  

闽ICP备14008679号