矩阵最小二乘法

1. 预备知识

1.1 从矩阵子空间角度理解矩阵向量乘

定义:设矩阵为的实数矩阵,则它的列空间为其所有列向量为基向量生成的上的子空间,记作.

结论:的结果可以看做是对向量的一种线性变换;也可以看做是矩阵的个列向量的线性组合,其中组合系数为 。显然,。

理解:设\mathbf{A}=\left[ \begin{matrix} 	a_{11}&		a_{12}&		\cdots&		a_{1n}\\ 	a_{21}&		a_{22}&		\cdots&		a_{2n}\\ 	\vdots&		\vdots&		\vdots&		\vdots\\ 	a_{m1}&		a_{m2}&		\cdots&		a_{mn}\\ \end{matrix} \right] ,,则

\begin{align} \mathbf{A}\boldsymbol{x}&=\left[ \begin{array}{c} 	a_{11}\\ 	a_{21}\\ 	\vdots\\ 	a_{m1}\\ \end{array} \right] x_1+\left[ \begin{array}{c} 	a_{12}\\ 	a_{22}\\ 	\vdots\\ 	a_{m2}\\ \end{array} \right] x_2+\cdots +\left[ \begin{array}{c} 	a_{1n}\\ 	a_{2n}\\ 	\vdots\\ 	a_{mn}\\ \end{array} \right] x_n \\ &=\boldsymbol{c}_1x_1+\boldsymbol{c}_2x_2+\cdots +\boldsymbol{c}_nx_n \end{align} \tag{1}

 .故,可看成,求解这样一个,它的各分量组成的系数能使得矩阵的个列向量的线性组合刚好等于向量。

1.2 垂直

向量与向量垂直:向量与向量垂直,则内积为0:

向量与空间垂直:向量与空间垂直,则的基向量都与垂直:

写成矩阵的紧凑形式:

即:


2. 线性最小二乘

由1.1知,无解,可理解为:,如:,。此时,一种很直观的解法为,求解这样一个近似解,它的各分量组成的系数能使得矩阵的个列向量的线性组合刚好等于向量 在中的投影,即.

利用投影性质及1.2内容:

\begin{align}\boldsymbol{e}\bot \boldsymbol{C}\left( \mathbf{A} \right) &\Longleftrightarrow \mathbf{A}^{\top}\boldsymbol{e}=\mathbf{0} \\&\Longleftrightarrow \mathbf{A}^{\top}\left( \boldsymbol{b}-\boldsymbol{\hat{b}} \right) =\mathbf{0} \\&\Longleftrightarrow \mathbf{A}^{\top}\left( \boldsymbol{b}-\mathbf{A}\boldsymbol{\hat{x}} \right) =\mathbf{0} \\&\Longleftrightarrow \mathbf{A}^{\top}\mathbf{A}\boldsymbol{\hat{x}}=\mathbf{A}^{\top}\boldsymbol{b} \end{align} \\

所以:


3. 非线性最小二乘

与线性情况类似,不过此时求解方程为,需要做一个线性化。

对在给定初始点处作一阶泰勒展开(假设可以这么展开):

上式中可看作是需要求解的当前点与真值点之间的差值。这时就可以用线性最小二乘方法求解问题了:

\mathbf{J}\Delta \boldsymbol{x}+f\left( \boldsymbol{x}_0 \right) =\boldsymbol{b}\\\mathbf{J}\Delta \boldsymbol{x}=\boldsymbol{b}-f\left( \boldsymbol{x}_0 \right) \\\therefore \Delta \boldsymbol{\hat{x}}=\left( \mathbf{J}^{\top}\mathbf{J} \right) ^{-1}\mathbf{J}^{\top}\left( \boldsymbol{b}-f\left( \boldsymbol{x}_0 \right) \right)

然后,修改当前点为,再进行线性化、求解线性最小二乘解,继续迭代下去,直至达到收敛条件(如到达最大迭代步数、步长小于阈值、前后误差变化小于阈值等等)为止了。至于泰勒展开和迭代的收敛性质则是另外的问题了。

另外,如果为代价函数,目标为最小化代价函数的平方,则令代入上式即可求解了。

你可能感兴趣的:(矩阵最小二乘法)