zoukankan      html  css  js  c++  java
  • 《Numerical Methods》-chaper7-解线性方程组的直接方法和最小二乘问题

      基于我们在线性代数中学习过的知识,我们知道解线性方程组本质上就是Gauss消元,也就是基于增广矩阵A的矩阵初等变换。关于数学层面的内容这里不做过多的介绍,这里的侧重点是从数值计算的角度来看这些常见的问题。

      那么基于Gauss消元的算法,我们将会很好理解如下的Matlab代码:

      for j = 1:n-1

       for i = j+1 : n

         mult = A(i,j)/A(j,j);

    A(i,:) = A(i,:) – mult*A(j,:);    %这里改写成A(i , j:n) = A(i,j:n) – mult*A(j,j:n)效率更高

    b(i) = b(i) – mult*b(j);         %这里的b是增光矩阵的最右一列向量,也就是方程组右侧常数部分

    end;

    end;

      这我们能够明显的看到,由于这里计算mult的时候涉及除法,所以无法处理A(j,j)=0的情况。

      关于这种一般化的Gauss消元,进行如下的时间复杂度的分析,这里我们以进行多少次浮点运算为衡量标准。

      写法1 :

    A(i,:) = A(i,:) – mult*A(j,:);

    这种情况下,进行的浮点运算数如下:

                             

    写法2:

      A(i , j:n) = A(i,j:n) – mult*A(j,j:n)

      这种写法相对第一种写法的优化,体现在在处理每一行的时候,自动跳过了该行前面为0的元素,以减少浮点运算的次数。

      它的运算次数计算过程如下:

     

       

      这里进行了相当精确的计算,可以看到,对于n x n的系数矩阵,完成Guess消元至少也需要进行n的三次方次浮点运算。

      承接上面对Guess消元算法的详细运算复杂度的分析,我们在分析时间复杂度的时候,往往会需要计算如下的一个和式:

                                 

      这里就简单的介绍一下这个和式的一个估算方法。

      我们利用幂函数与x轴围成的面积,使用一个类似夹逼准则的手法,来对这个和式进行估算。

     

      我们将幂函数y = x^p,横坐标取m份,间距为1。

      那么和式其实就是图中矩阵的和,那么我们很容易能够看到如下的一个不等式成立:

       

      而这里我们观察前4个矩形上面的小矩形,他们和实际上等于第5个矩形,因此我们容易看到如下的不等式:

       

      因此这个和式成功的被两个定积分给“夹逼”了,下面分别求定积分。

       

       

       求线性方程组Ax=b的几种方法的比较:

      

     

                               

                               

  • 相关阅读:
    Qt源文件和ui文件的关系
    使用moveToThread线程并正确回收内存的方式
    mysql设置某字段不可重复
    使用curl创建简单的性能监控工具
    你是不是那个带不动的队友
    这样的面试你能通过吗
    浅谈测试观
    自动化测试如何准备测试数据
    关于双十二崩盘的一些思考
    浅谈测试环境
  • 原文地址:https://www.cnblogs.com/rhythmic/p/5789448.html
Copyright © 2011-2022 走看看