Processing math: 100%
0%

【线性代数】正交投影

​ 我们在初中就应该学过投影,那么什么是投影呢?形象点说,就是将你需要投影的东西上的每一点向你要投影的平面作垂线,垂线与平面的交点的集合就是你的投影。注意这里我们的投影是向量的投影,几何的投影(并不一定是垂直投影的)可见度娘百科。同样的,我们从简单的二维投影来开始讨论。


二维投影

上图表示的是,向量b在向量a上的投影为p。显然有如下表达式:

e=bp=bxaaTe=0aT(bxa)=0xaTa=aTbx=aTbaTap=ax=aaTbaTaPb=pP=aaTaTa

其中,P为投影矩阵,由P的表达式可以看出,它具有如下性质:

PT=P,P2=P

三维投影

三维投影,就是将一个向量投影到一个平面上。同上面一样,假设b向量在平面上的投影为p,则有表达式:

e=bp

e是垂直于平面的向量。由于p向量在平面上,则p向量可以由该平面的2个线性无关向量(正如,在xy平面的任何向量都可以由x轴,y轴表示)表示:

p=x1a1+x2a2=AxA=[a1a2]x=[x1x2]T

由于e垂直于平面,则e向量垂直于平面中的任意向量,则有:

{e=bp=bAxaT1(bAx)=0aT2(bAx)=0[aT1aT2][bAx]=0AT(bAx)=0

将上式化简求得x

ATAx=ATbx=(ATA)1ATb

又因为p=Ax, Pb=p则得到投影矩阵为:

P=A(ATA)1AT

P的表达式可以看出,它具有如下性质:

PT=P,P2=P

上面的投影矩阵是通式,当投影在一维情况时,A即为直线上的任意一个向量a,投影矩阵为:

P=A(ATA)1AT=a(aTa)1aT=aaTaTa

注意:一个数值的逆是它的倒数。


举例说明

下面以一个实例来说明:

如上图,假设我们要将向量b投影到水平面上,其投影为pa1, a2为水平面的两个线性无关向量,它们的参数分别为:

b=[111],a1=[100],a2=[010]

那么A=[a1a2]即:

A=[100100]

由上面我们求得的通式,可得投影矩阵P:

P=A(ATA)1AT=[100010000]

知道投影矩阵P后,我们可以得到b在水平面上的投影p为:

p=Pb=[100010000][111]=[110]

显然,p与我们图中所示的结果相同。这里我们是以三维情况进行举例的,更高维情况,我们无法用图像来描述,但是通式也是成立的。

三维图的matlab程序如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
clear all
clc

a1=[1 0 0];
a2=[0 1 0];
b=[1 1 1];
p=[1 1 0];
e=b-p;
quiver3(0,0,0,a1(1),a1(2),a1(3),1,'color','r')
hold on
quiver3(0,0,0,a2(1),a2(2),a2(3),1,'color','r')
hold on
quiver3(0,0,0,b(1),b(2),b(3),1,'color','g')
hold on
quiver3(0,0,0,p(1),p(2),p(3),1,'color','g')
hold on
quiver3(p(1),p(2),p(3),e(1),e(2),e(3),1,'color','b')
坚持原创技术分享,您的支持将鼓励我继续创作!