一、定义转向算法

 在第六节讲了空间,列空间,零空间的定义,这节主要讲解如何求出这些空间,即求解$Ax=0$的过程是怎么样的过程,以下面的矩阵$A$为例:(这里主要是长方阵)

$A=\left[\begin{array}{llll}{1} & {2} & {2} & {2} \\ {2} & {4} & {6} & {8} \\ {3} & {6} & {8} & {10}\end{array}\right]$

仔细观察上面的矩阵就会发现行列之间的关系:第二列是第一列的2倍,第三行是前两行的和

 1)消元:零空间不会变,因为方程解不变

  第一阶段(找到第一个主元):$\left[\begin{array}{llll}{1} & {2} & {2} & {2} \\ {0} & {0} & {2} & {4} \\ {0} & {0} & {2} & {4}\end{array}\right]$

第二阶段(找第二个主元,发现是0,也无法通过后面的行交换来使得该位置不为0,我们就将0后面的2当作主元,继续对下面的行消元)

$\left[\begin{array}{llll}{1} & {2} & {2} & {2} \\ {0} & {0} & {2} & {4} \\ {0} & {0} & {0} & {0}\end{array}\right]=U$

  综上:我们已经找到了两个主元1和2,这里我们知道主元的数量是2,所以矩阵的秩就是2,矩阵的秩(rank)即为矩阵的主元数量

  我们原本要求$Ax=0$,现在经过消元,方程解不变,现在只需要求$Ux=0$

 2)主列和自由列

  主元所在的列为主列(如第一列和第三列),另外的是自由列(如第二列和第四列),所谓自由列就是我们可以任意分配其对应的未知变量的系数,如$x_2=1, x_4=0$

$x_{1}+2 x_{2}+2 x_{3}+2 x_{4}=0$
$2 x_{3}+4 x_{4}=0$

则方程解为:$x=\left[\begin{array}{c}{-2} \\ {1} \\ {0} \\ {0}\end{array}\right]$

当然也存在下面的解:$x=C\left[\begin{array}{c}{-2} \\ {1} \\ {0} \\ {0}\end{array}\right]$

  我们说过,自由列的存在使得我们可以为自由变量随意分配值,所以当然$x_2=0, x_4=1$也是可以的:

则方程解为:$x=\left[\begin{array}{c}{2} \\ {0} \\ {-2} \\ {1}\end{array}\right]$

当然也存在下面的解:$x=d\left[\begin{array}{c}{2} \\ {0} \\ {-2} \\ {1}\end{array}\right]$

有了上面两个特定解,我们就可以求出所有x,即矩阵的零空间:$x=C\left[\begin{array}{c}{-2} \\ {1} \\ {0} \\ {0}\end{array}\right] + d\left[\begin{array}{c}{2} \\ {0} \\ {-2} \\ {1}\end{array}\right]$

所以矩阵的零向量就是特定解的线性组合

零空间的求法:对矩阵A进行消元求得主变量和自由变量;给自由变量赋值得到特解;对特解进行线性组合得到零空间

 3)简化U:下面我们将会简化U来得到R

  简化的过程:从U出发,将主元上下全变为0,即$\left[\begin{array}{llll}{1} & {2} & {0} & {-2} \\ {0} & {0} & {2} & {4} \\ {0} & {0} & {0} & {0}\end{array}\right]$,然后将主元变为1即得到简化行阶梯形式R

$\left[\begin{array}{cccc}{1} & {2} & {0} & {-2} \\ {0} & {0} & {1} & {2} \\ {0} & {0} & {0} & {0}\end{array}\right]=R$

从上面的过程看出,全0的行是其他行的线性组合(行一减去行二,行二除以2)

  整个过程从求解$Ax=0$,消元变为$Ux=0$,简化变为$Rx=0$,熟悉了整个过程,Matlab中很容易实现这个过程$R = rref(A)$

  上面的过程如下所示:

$\left[\begin{array}{llll}{1} & {2} & {2} & {2} \\ {2} & {4} & {6} & {8} \\ {3} & {6} & {8} & {10}\end{array}\right] \rightarrow\left[\begin{array}{cccc}{1} & {2} & {2} & {2} \\ {0} & {0} & {2} & {4} \\ {0} & {0} & {0} & {0}\end{array}\right] \rightarrow\left[\begin{array}{cccc}{1} & {2} & {0} & {-2} \\ {0} & {0} & {1} & {2} \\ {0} & {0} & {0} & {0}\end{array}\right]$

 二、换一个角度

 上面我们从数值解的角度描述了矩阵零空间的求法,下面从公式角度分析:

 上面我们经过消元得到了最简形式R。我们将R经过列变换得到如下矩阵(交换二三列):

$\bar{R}=\left[\begin{array}{cccc}{1} & {0} & {2} & {-2} \\ {0} & {1} & {0} & {2} \\ {0} & {0} & {0} & {0}\end{array}\right]$

 同时,我们可以对方程式作如下变形:

$x=\left[x_{1}, x_{2}, x_{3}, x_{4}\right]$

$\bar{x}=\left[x_{1}, x_{3}, x_{2}, x_{4}\right]$

 方程的解不会发生变化,只是顺序变了,我们将$\bar{R}$划分区域:

$I_{2 \times 2}=\left[\begin{array}{cc}{1} & {0} \\ {0} & {1}\end{array}\right], F_{2 \times 2}=\left[\begin{array}{cc}{2} & {-2} \\ {0} & {2}\end{array}\right]$

 所以$\bar{R}$将变为:

$\bar{R}=\left[\begin{array}{cc}{I_{2 \times 2}} & {F_{2 \times 2}} \\ {0_{1 \times 1}} & {0_{1 \times 1}}\end{array}\right]$

 最终解方程变成了:

$R x=0 \rightarrow \bar{R} \bar{x}=0$

 代入方程得到零空间:

$\bar{R} \bar{x}=0_{3 \times 1} \rightarrow\left[\begin{array}{cc}{I_{2 \times 2}} & {F_{2 \times 2}} \\ {0_{1 \times 1}} & {0_{1 \times 1}}\end{array}\right]\left[\begin{array}{c}{-F_{2 \times 2}} \\ {I_{2 \times 2}}\end{array}\right]=-I_{2 \times 2} F_{2 \times 2}+F_{2 \times 2} I_{2 \times 2}=0$

$\rightarrow \bar{x}=\left[\begin{array}{c}{-F_{2 \times 2}} \\ {I_{2 \times 2}}\end{array}\right]=\left[\begin{array}{cc}{-2} & {2} \\ {0} & {-2} \\ {1} & {0} \\ {0} & {1}\end{array}\right]$

 我们再将$x_2,x_3$进行位置互换:

$x=\left[\begin{array}{cc}{-2} & {2} \\ {1} & {0} \\ {0} & {-2} \\ {0} & {1}\end{array}\right]$

这两个特解与之前我们求得的特解一致

三、实例练习

 有一矩阵$A$:

$A=\left[\begin{array}{ccc}{1} & {2} & {3} \\ {2} & {4} & {6} \\ {2} & {6} & {8} \\ {2} & {8} & {10}\end{array}\right] \rightarrow\left[\begin{array}{ccc}{1} & {2} & {3} \\ {0} & {2} & {2} \\ {0} & {0} & {0} \\ {0} & {0} & {0}\end{array}\right] \rightarrow\left[\begin{array}{ccc}{1} & {0} & {1} \\ {0} & {1} & {1} \\ {0} & {0} & {0} \\ {0} & {0} & {0}\end{array}\right]$

这样矩阵$A$就经过$U$变成了$R$

 由于$R$本来就具有很好的形式,就不用进行列变换了:

$I_{2 \times 2}=\left[\begin{array}{cc}{1} & {0} \\ {0} & {1}\end{array}\right], F_{2 \times 1}=\left[\begin{array}{l}{1} \\ {1}\end{array}\right]$

$R_{4 \times 3}=\left[\begin{array}{ll}{I_{2 \times 2}} & {F_{2 \times 1}} \\ {0_{2 \times 2}} & {0_{2 \times 1}}\end{array}\right]$

$R_{4 \times 3} x_{3 \times 1}=0_{4 \times 1} \rightarrow\left[\begin{array}{cc}{I_{2 \times 2}} & {F_{2 \times 1}} \\ {0_{2 \times 2}} & {0_{2 \times 1}}\end{array}\right]\left[\begin{array}{c}{-F_{2 \times 1}} \\ {I_{1 \times 1}}\end{array}\right]=\left[\begin{array}{c}{-I_{2 \times 2} F_{2 \times 1}+F_{2 \times 1} I_{1 \times 1}=0_{2 \times 1}} \\ {0_{2 \times 1}}\end{array}\right]$

 所以:

$x_{3 \times 1}=\left[\begin{array}{c}{-F_{2 \times 1}} \\ {I_{1 \times 1}}\end{array}\right]=\left[\begin{array}{c}{-1} \\ {-1} \\ {1}\end{array}\right]$

 注:最简矩阵R和零空间矩阵x在MATLAB中可以分别用命令rref(A),null(A,'r')得到

 本文实例参考,请点击

07-求解Ax=0:主变量、特解的更多相关文章

  1. MIT线性代数:7.主变量,特解,求解AX=0

  2. 求解Ax=b

    一 线性方程组 Ax=b 的解释 线性方程组 Ax=b,其中矩阵 A 尺寸为 m*n, 当 A 为方正时,可使用消元法判断解是否存在并求解.当 A 为长方形矩阵时,同样可使用消元法判断解存在情况并求解 ...

  3. phpinfo() 中 Local Value(局部变量)Master Value(主变量) 的区别

    [题外话]phpinfo()这个函数可以查看很多php的信息,要 记得使用 phpinfo() 的很多部分有两个Column:Local Value(局部变量)和 Master Value(主变量) ...

  4. AS3.0定义变量的访问范围

    在AS3.0中变量的默认访问范围是:internal:包内成员可以访问,包外不可访问.AS2.0默认访问范围是public

  5. 07、NetCore2.0依赖注入(DI)之生命周期

    07.NetCore2.0依赖注入(DI)之生命周期 NetCore2.0依赖注入框架(DI)是如何管理注入对象的生命周期的?生命周期有哪几类,又是在哪些场景下应用的呢? -------------- ...

  6. jdk1.8.0环境变量设置

    jdk1.8.0环境变量设置 1.jdk安装完毕 打开如下链接:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloa ...

  7. [转]Tomcat9.0安装教程 Tomcat9.0环境变量配置教程

    [转]Tomcat9.0安装教程 Tomcat9.0环境变量配置教程 [转]超详细MySQL安装及基本使用教程

  8. python求解ax² + bx + c = 0

    系数需满足条件: a,b不能同时为0 b2-4ac≠0 代码如下def quadratic(a, b, c): """ 返回ax² + bx + c = 0的 " ...

  9. shell中$0,$?,$!等变量意义

    变量说明:   $$     #Shell本身的PID(ProcessID) $!     #Shell最后运行的后台Process的PID $?     #最后运行的命令的结束代码(返回值) $- ...

随机推荐

  1. 【PowerOJ1742&网络流24题】试题库问题(最大流)

    题意: 思路: [问题分析] 二分图多重匹配问题,用最大流解决. [建模方法] 建立二分图,每个类别为X集合中的顶点,每个题为Y集合中的顶点,增设附加源S和汇T. 1.从S向每个Xi连接一条容量为该类 ...

  2. VUE环境搭建,项目配置(Windows下)

    公司想做官网,框架我自己定,然后就选了vue,那现在就来加深一遍vue的环境的搭建吧 1.安装node.js,这里就不再多说了,很简单,如果之前有安装就不用再安装了,可node -v查看node版本 ...

  3. 电脑新安装JDK版本并运行使用该JDK版本问题

    情景:电脑上已正常安装一个jdk版本,如:1.7.0_71,因考虑到一些情况,现需要使用版本为1.7.0_80(1.8),故需新安装JDK,并使服务可以运行使用新安装的JDK版本. 网络找寻方法: ( ...

  4. linux/Unix下的vim/vi指令的使用方法

    概述 以下这篇文章介绍的是关于vim的使用方法,由于我本身对linux没有太多的研究,写下的这篇文章纯属是在实际中经常使用vim指令,想通过这篇文章记录下来,方便以后使用时查找方便.个人认为,对于普通 ...

  5. 主流Linux可视化运维面板&安装包

    一.AMH面板 1.官方网站 官方网站:http://amh.sh 2.面板介绍 截止到AMH4. 2 版本都是提供免费安装的,后来从5. 0 开始提供付费安装,可以理解开发者的盈利问题,毕竟提供免费 ...

  6. [CF Round603 Div2 F]Economic Difficulties

    题目:Economic Difficulties 传送门:https://codeforces.com/contest/1263/problem/F 题意:给了两棵tree:Ta(拥有a个节点,节点编 ...

  7. 转载:String.format()的详细用法

    转载自:https://blog.csdn.net/anita9999/article/details/82346552 问题 在开发的时候一段字符串的中间某一部分是需要可变的 比如一个Textvie ...

  8. a daemon 守护进程

    w Cron and Crontab usage and exampleshttps://www.pantz.org/software/cron/croninfo.html

  9. rac的一次问题 ORA-01565: error in identifying file '+DATA/bol/spfilebol.ora'

    昨天安装的测试环境的rac--2节点 CentOS release 6.8 (Final) SQL*Plus: Release 11.2.0.4.0 Production 今天测试突然出现问题 在ra ...

  10. PHP多图片上传 并检查 加水印 源码

    参数说明:$max_file_size : 上传文件大小限制, 单位BYTE$destination_folder : 上传文件路径$watermark : 是否附加水印(1为加水印,其他为不加水印) ...