SQR逐次超松弛迭代法(matlab代码实现)

SQR迭代法是对GS迭代法的又一改进,在每一解向量分量处取其先前分量与GS迭代法算出的分量值的加权平均。
其中w松弛因子决定了加权的系数,若SQR方法收敛,则w的取值范围为0~2。
代码如下:

A=[4,3,0;3,4,-1;0,-1,4]
b=[24;30;-24]
function x=SQR(A,b)
% SQR逐次超松弛迭代法。
% 输入参数: 
%   A: 矩阵
%   b: 向量 
%   w: 松弛因子
%   x: 初始向量 
% 输出参数:
%   x:迭代得到的解向量
% 调用说明:
%   x=SQR(A,b):调用函数迭代求出AX=b的解X。
 
% 版本号V1.5,编写于2019年8月20号,修改于2019年8月20号,作者:Hiper
n=length(b);
M=zeros(n);
N=-A;
for i=1:n
    M(i,i)=A(i,i);
    N(i,i)=0;
end
B=M^-1*N;
f=M^-1*b;

while 1
    w=input('请输入松弛因子w:');
    if w<0||w>2
        disp('松弛因子大小不正确,请重新输入!');
    else
        break;
    end
end

while 1
    x=input('请输入初始解向量x_0:');
    if size(x)~=size(b)
        disp('解向量大小不正确,请重新输入!')
    else
        break;
    end
end

time=0;

while 1        %实现do while循环
    for i=1:n
        x(i)=w*(B(i,:)*x+f(i))+(1-w)*x(i);
    end
    time=time+1;
    if norm(b-A*x)<(10e-7)    %当解向量收敛到小于10e-7时结束迭代。
         break;
    end  
 end  
fprintf('总共迭代次数为%d',time);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值