`
海王子1994
  • 浏览: 45215 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

用Matlab编写超松弛迭代法与列主元消去法

 
阅读更多

作为迭代法一种加速方法,超松弛迭代法计算公式简单,只是需要选择合适的松弛因子,保证迭代过程有较快的收敛速度。它是Gauss-Seidel迭代法的优化。而列主元消去法,因为仅按列选主元,相比完全主元消元法,省了主元搜寻时间,提高了效率。

 

SOR迭代公式:



 

 SOR编程代码如下:

 

     函数:

function [xvect,nvect,xdif]=SOR(A,b,eps,x0,w) %超松弛迭代法
m=length(b); %m为线性方程组的维数,即变量的个数
xvect=[]; %为length(b)行length(nvect)列的矩阵,存储X1~X(length(b))变量的迭代值
nvect=[]; %存贮迭代次数
xdif=[];  %存储误差 max(1<=i<=length(b))abs(xi(k+1)-xi(k))
n=1; xvect=[xvect;x0];
x1=[];
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%计算由初值x0经第一次迭代后的值x1
x1(1)=x0(1)+w/A(1,1)*(b(1)-sum(A(1,[1:m]).*x0([1:m])));
for i=2:m-1
    x1(i)=x0(i)+w/A(i,i)*(b(i)-sum(A(i,[1:i-1]).*x1([1:i-1]))-sum(A(i,[i:m]).*x0([i:m])));
end
x1(m)=x0(m)+w/A(m,m)*(b(m)-sum(A(m,[1:m-1]).*x1([1:m-1]))-A(m,m)*x0(m));
xvect=[xvect;x1];nvect=[nvect;n];err=max(abs(x0-x1));xdif=[xdif;err];
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%下面是迭代过程
while(err>eps)
    x2=x1;
    x1(1)=x1(1)+w/A(1,1)*(b(1)-sum(A(1,[1:m]).*x1([1:m])));
    for i=2:m-1
        x1(i)=x1(i)+w/A(i,i)*(b(i)-sum(A(i,[1:i-1]).*x1([1:i-1]))-sum(A(i,[i:m]).*x1([i:m])));
    end
    x1(m)=x1(m)+w/A(m,m)*(b(m)-sum(A(m,[1:m]).*x1([1:m])));
    n=n+1;err=max(abs(x1-x2));
    xvect=[xvect;x1];nvect=[nvect;n];xdif=[xdif;err];
end

 

 

   脚本:

clear;
A=[3 2 1;2 3 1;1 2 3]; b=[39 34 26]; eps=10^(-5);x0=[0 0 0];w=1.2;%给定初值
[x,n,err]=SOR(A,b,eps,x0,w); %调用SOR迭代法

%下面的输出到屏幕上 
 fprintf('         k        x1             x2        x3             err\n');
for i=1:length(n)
    fprintf('%10.0f   %10.6f    %10.6f   %10.6f   %10.6f\n',n(i),x(i,1),x(i,2),x(i,3),err(i));  
    i=i+1;
end

 

结果:



 

 

列主元消去法:

 

   函数:

function [x,U,M]=GaussEliminate_column(A,b) %Gauss选列主元消去法
n=length(b);
M=[];
%下面是消元过程
for k=1:n
    for i=k+1:n
        if A(k,k)~=0
           M(i,k)=A(i,k)/A(k,k);
           b(i)=b(i)-M(i,k)*b(k);
           for j=k+1:n
               A(i,j)=A(i,j)-M(i,k)*A(k,j);
           end
        else
            %遍历当前位置所在的列,进行消元过程
            for m=k+1:n
                if A(m,k)==max(A([k+1;n],k))%找到所在位置所处列以后最大的元素
                    %将最大元素与当前元素调换位置
                    B=A(k,[1:n]);
                    A(k,[1:n])=A(m,[1:n]);
                    A(m,[1:n])=B;
                    %将相应在b的元素也调换位置
                    temp=b(t);
                    b(t)=b(k);
                    b(k)=temp;
                end
            end
                    
        end
    end
end
%下三角化零
for i=1:n
    for j=1:i-1
        A(i,j)=0;
    end
end
U=A;
%下面是回代过程
x(n)=b(n)/A(n,n);
for i=n-1:-1:1
    x(i)=(b(i)-sum(A(i,[i+1:n]).*x([i+1:n])))/(A(i,i));
end

 

 

   脚本:

 

 

clear;
A=[3 2 1;2 3 1;1 2 3];b=[39 34 26];
[x,U,M]=GaussEliminate_column(A,b); %Gauss列主元消去法

%下面的输出到屏幕上 
 fprintf('x1=             x2=           x3=       \n');
 fprintf('   %10.5f    %10.5f    %10.5f   \n',x(1),x(2),x(3));  
 fprintf('U=    \n');
 for i=1:length(b)
     fprintf('   %10.5f    %10.5f    %10.5f   \n',U(i,1),U(i,2),U(i,3));
 end

 

 

关键代码:

 %遍历当前位置所在的列,进行消元过程
            for m=k+1:n
                if A(m,k)==max(A([k+1;n],k))%找到所在位置所处列以后最大的元素
                    %将最大元素与当前元素调换位置
                    B=A(k,[1:n]);
                    A(k,[1:n])=A(m,[1:n]);
                    A(m,[1:n])=B;
                    %将相应在b的元素也调换位置
                    temp=b(t);
                    b(t)=b(k);
                    b(k)=temp;
                end
            end

 

 

结果:



 

 

 

  • 大小: 2.7 KB
  • 大小: 8.2 KB
  • 大小: 18.7 KB
分享到:
评论

相关推荐

    数值分析上机作业代码及报告

    本文档主要介绍了数值分析上机作业代码及报告,涵盖了舍入误差与有效数、Newton 迭代法、列主元 Gauss 消去法、逐次超松弛迭代法、3 次样条插值函数、重积分的计算、常微分方程初值问题数值解等多个数值分析方向。...

    选主元的Gauss消去法和不选主元的Gauss消去法实验报告含源码

    实验中提供了C++代码实现,展示了如何运用Gauss列主元消去法求解线性方程组,以及如何进行不选主元的Gauss消去法。代码中包含了数据输入、矩阵显示、行交换和行消元等关键步骤,通过运行结果对比,可以明显看出选...

    数值分析计算方法实验报告.pdf

    在实验中,我们使用MATLAB语言来实现超松弛迭代法,并输出了计算结果。 通过实验,我们可以看到不同的方法在解决线性方程组时的优缺点。高斯列主元消去法可以快速地求解线性方程组,但是需要将矩阵分解为上三角矩阵...

    线性方程组求解 matlab代码

    超松弛迭代法是Gauss-Seidel方法的优化,引入松弛因子以加速收敛。在MATLAB中,可以编写迭代程序并调整松弛因子来应用SOR方法。 8. **Jordan法求逆矩阵**: Jordan法是通过Jordan矩阵来求解矩阵的逆,但实际应用...

    王能超-计算方法——算法设计及MATLAB实现课后代码.pdf

    线性方程组的迭代法和直接法方面涵盖了Jacobi迭代、Gauss-Seidel迭代、超松弛迭代、对称超松弛迭代等。 以下是每章节的详细知识点: 第一章 插值方法 * 1.1 Lagrange插值:计算Lagrange插值多项式在x=xO处的值,...

    MATLAB常用算法

    SSOR 对称逐次超松弛迭代法求线性方程组Ax=b的解 JOR 雅可比超松弛迭代法求线性方程组Ax=b的解 twostep 两步迭代法求线性方程组Ax=b的解 fastdown 最速下降法求线性方程组Ax=b的解 conjgrad 共轭梯度法求线性方程组...

    MATLAB语言常用算法程序集

    SSOR 对称逐次超松弛迭代法求线性方程组Ax=b的解 JOR 雅可比超松弛迭代法求线性方程组Ax=b的解 twostep 两步迭代法求线性方程组Ax=b的解 fastdown 最速下降法求线性方程组Ax=b的解 conjgrad 共轭梯度法求线性方程组...

    数值分析+编程代码汇总+追赶法、拉格朗日插值、最小二乘法、不动点迭代、雅可比迭代、牛顿法下山法、割线法、乘幂法

    线性方程组的迭代法:Jacobi迭代法、Gauss-Seidel迭代法(利用前者每次迭代已得到的最新分量加速)、逐次超松弛(SOR,Successive Over-Relaxation)方法 函数拟合的插值法:拉格朗日(Lagrange)插值法与牛顿...

    王能超-计算方法——算法设计及MATLAB实现课后代码.docx

    迭代法,如Gauss-Seidel迭代和超松弛迭代(包括对称超松弛迭代),用于求解大型线性系统的近似解。 ### 第六章 线性方程组的直接法 包括追赶法、Cholesky方法和矩阵分解方法,如Gauss列主元消去法,这些直接方法可...

    王能超 计算方法——算法设计及MATLAB实现课后代码.pdf

    - **对称超松弛迭代**:在对称线性系统中,对称超松弛迭代(SOR)进一步优化了超松弛迭代,通常收敛更快。 6. **线性方程组的直接法** - **追赶法**:用于解三角形矩阵的线性方程组,通过前向或后向代入求解。 -...

    王能超 计算方法——算法设计及MATLAB实现课后代码解析.doc

    文档"王能超 计算方法——算法设计及MATLAB实现课后代码解析.doc"主要涵盖了数值计算领域的多个重要主题,包括插值方法、数值积分、常微分方程的差分方法、方程求根、线性方程组的迭代法以及直接法。以下是对这些...

Global site tag (gtag.js) - Google Analytics