向量公式总结。

定理1.1,对于给定的任何两个系数a和b,以及任何三个向量P,Q和R,存在一下运算规律

1P + Q = Q + P 

2(P + Q) + R = P + (Q + R)

3(ab)P = a(bP)

4a(P + Q) = aP + aQ

5(a + b)P = aP + bP


定理1.2 对于任意给定的系数a,以及任意的两个向量P与Q,有一下性质:

1|| P || ≧ 0

2当且仅当P = <0, 0, 0 >时,|| P || = 0

3|| aP || = | a | * || P ||

4|| P + Q || ≦ || P || + || Q ||我给出这个公式的推导过程


aes android 向量 向量ap=xab+yac_struct




假设a( xa, ya ), b( xb, yb ), c( xc, yc )

a + b = c

[ ( xa + xb )² + ( ya + yb )² ]½ ≦ ( xa² + ya² )½ + ( xb² + yb² )½

xa² + xb² +2xaxb + ya² + yb² +2yayb ≦ xa² + ya² + xb² + yb² + 2( xa² + ya² )½ *( xb² + yb² )½

2xaxb + 2yayb ≦ 2( xa² + ya² )½ *( xb² + yb² )½

xaxb + yayb ≦ ( xa² + ya² )½ *( xb² + yb² )½

( xaxb + yayb )² ≦ ( xa² + ya² )( xb² + yb² )

xa²xb² + ya²yb² + 2xa²xbyayb ≦ xb²xb² +xa²xb² + xa²yb² + ya²xb² + ya²yb²

2xaxbyayb ≦ xa²yb² + ya²yb²



根据不等式公式


aes android 向量 向量ap=xab+yac_算法_02




令 xa²yb² = a²

ya²yb² = b²

2xaxbyayb = 2ab 

满足上面的公式a² + b² ≧ 2ab证明完毕!


点积定义:两向量的数量积等于其中一个向量的模与另一个向量在这个向量的方向上的投影的乘积。

定理1.3两个n维向量P和Q的点积记作

aes android 向量 向量ap=xab+yac_aes android 向量_03

定理1.4对于给定的两个向量P和Q,点积P·Q满足下面个公式

P· Q = || P || || Q|| cosα 我给出这个公式的推导证明


aes android 向量 向量ap=xab+yac_struct_04



P`为P在Q上的投影

因为|| P` || = || P || cosα

所以P· Q = || P` || * || Q || = |

定理1.41 P· Q的值影响向量方向

1 P· Q > 0  两个向量方向相近

2 P· Q = 0  两个向量相互垂直

3 P· Q < 0  两个向量方向相反


定理 1.5 对于任意给定的系数a和任意三个

1 P · Q = Q · P

2 ( aP ) · Q = a( Q · P )

3 P · ( Q + R ) = P · Q + P · R

4 P · P = || P ||²

5 | P · Q | ≦ || P || || Q ||

P( x1, y1 ), Q( x2, y2 )

| P · Q | ≦ || P || || Q ||

( x1x2 + y1y2 )² ≦ ( x1² + y1² )½ * ( x2² + y2

X1²x2² + y1²y2² + 2x1x2y1y2 ≦ ( x1² + y1² )

2x1x2y1y2 ≦ x1²y2² + y1²x2²

令 x1y2 = a, y1x2 = b

x1²y2² = a², y1²x2² = b², 2x1x2y1y2 = 2ab

根据不等式公式


aes android 向量 向量ap=xab+yac_算法_02


a² + b² ≧证明完毕!



定理 1.5.1 投影公式

P在Q上的投影P`




aes android 向量 向量ap=xab+yac_struct_04


aes android 向量 向量ap=xab+yac_float_07

我给出这个公式的证明

P · Q = || P || || Q ||cosα

|| P || cosα = ( P · Q ) / || Q ||

|| P || cosα就是P在Q上的投影长度|| P` ||

Q / || Q || 就是单位向量乘以 P在Q上的投影长度而得到的向量P`


叉积定义

定理1.6 两个3D向量P和Q的叉积记作

1 P × Q = < PyQz - PzQy, PzQx - PxQz, PxQy - PyQx >

定理1.7 设P和Q为任意的两个3D向量,则有

1 ( P × Q ) · P = 0 我给出这个公式的证明

< PyQz - PzQy, PzQx - PxQz, PxQy - PyQx > · P 

= PyQzPx - PzQyPx + PzQxPy - PxQzPy + PxQyPz - PyQxPz

= 0

定理1.8 对于给定的两个3D向量P和Q,他们的叉积P × Q 满足下面的公式

1 || P × Q || = || P || || Q || sinα 我给出这个公式的证明

所得的向量求模

(|| P × Q ||)²  = || < PyQz - PzQy, PzQx - PxQz, PyQx - PxQy >||²

= ( PyQz - PzQy )² + ( PzQx - PxQz )² + ( PyQx - PxQy )²

=  Px²Qy² + Px²Qz² + Py²Qx² + Py²Qz² + Pz²Qx² + Pz²Qy² + 

2PxPyQxQy + 2PxPzQxQz + 2PxPyQxQy

在公式里加上(Px²Qx² + Py²Qy² + Pz²Qz²) 再减去(Px²Qx² + Py²Qy² + Pz²Qz²)

得到:

( Px²Qy² + Px²Qz² + Py²Qx² + Py²Qz² + Pz²Qx² + Pz²Qy² + Px²Qx² + Py²Qy² + Pz²Qz² ) -

( Px²Qx² + Py²Qy² + Pz²Qz² - 2PxPyQxQy - 2PxPzQxQz - 2PxPyQxQy )

(|| P × Q ||)² = ( Px² + Py² + Pz² )( Qx² + Qy² + Qz² ) - ( PxQx + PyQy - PzQz )²

(|| P × Q ||)² = || P ||² || Q ||² - ( P · Q )²

   = || P ||² || Q ||² - P² · Q²

因为P· Q = || P || || Q|| cosα

所以 = || P ||² || Q ||² - || P ||² || Q||² cos²α

= || P ||² || Q ||² ( 1 - cos²α )

= || P || || Q || sinα


定理 1.9 对于给定的两个系数a和b和任意三个3D向量P,Q和R,有一下性质存在:

1 P × Q = -( P × Q )

2 (aP) × Q = a( P × Q ) 

3 P × ( Q + R ) = P × Q + P × Q

4 P × P = 0 = < 0, 0, 0 >

5 ( P × Q ) · R = ( R × P) · Q = ( Q × R ) · P

6 P × ( Q × P ) = P × Q × P = P²Q - ( P · Q )P 我给出这个公式的证明

P × ( Q × P )  = P × [ - ( P × Q ) ]

假设P × Q = R

= P × ( -R )

= - [ ( -R ) × P ]

= R × P

= P × Q × P

P × Q × P  =  P²Q - ( P · Q )P

( < PyQz - PzQy, PzQx - PxQz, PxQy - PyQx > × P )

先对x分量进行求值

( PzQx - PxQz ) * Pz - ( PxQy - PyQx ) * Py

= Pz²Qx + Py²Qx - PxQzPz - PxQyPy

= ( Pz² + Py² ) * Qx - ( QzPz + QyPy ) * Px

在上面的算式中加上 Px²Qx 再减去 Px²Qx

= ( Pz² + Py² ) * Qx + Px²Qx - ( QzPz + QyPy ) * Px - Px²Qx

= ( Px² + Py² + Pz² ) * Qx  - ( QzPz + QyPy + PxQx ) * Px

= P²Qx - ( P · Q )Px

再对 y 分量进行求值

( PxQy - PyQx ) * Px - ( PyQz - PzQy ) * Pz

= Px²Qy + Pz²Qy - PyQxPx - PyQzPz

= ( Px² + Pz² ) * Qy - ( QxPx + QzPz ) * Py

在上面的算式中加上 Py²Qy 再减去 Py²Qy

= ( Px² + Pz² ) * Qy + Py²Qy - ( QxPx + QzPz ) * Py - Py²Qy

= ( Px² + Py² + Pz² ) * Qy - ( QxPx + QyPy + QzPz ) * Py

= P²Qy - ( P · Q )Py

最后对 z 分量进行求值

( PyQz - PzQy ) * Py - ( PzQx - PxQz ) * Px

= Py²Qz + Px²Qz - PzQyPy - PzQxPx

= ( Py² + Px² ) * Qz - ( QyPy + QxPx ) * Pz

再上面的算式中加上 Pz²Qz 再减去 Pz²Qz

= ( Py² + Px² ) * Pz²Qz - ( QyPy + QxPx ) * Pz - Pz²Qz 

= ( Px² + Py² + Pz² ) * Qz - ( QxPx + QyPy + QzPz ) * Pz

= P²Qz - ( P · Q )Pz

所以上面等于下面的等式

P × Q × P  =  < P²Qx - ( P · Q )Px, P²Qy - ( P · Q )Py, P²Qz - ( P · Q )Pz >

 =  P²Q - ( P · Q )P


定理 1.10 向量空间是一个集合 V,它的元素称为向量。在这里定义空间中的假发运算和数乘运算,并介绍向量空间的一些性质。

1V对于加法运算封闭。 也就是说, 对于V 中的任意向量P和Q,他们的和 P + Q

仍然是V的元素。

2V对于数乘运算封闭。 也就是说,对于任意的实数a和V中的任意向量P,数乘aP

仍然是V的元素。

3向量空间V中存在一个元素0,对于V中的任意元素P,P+0 = 0 +P=P。

4对于向量空间V中的任意元素P,在向量空间V中存在对应的向量Q,使得P+Q = 0。

5加法满足结合律。也就是说,对于V中任意的向量P,Q和R,(P+Q)+R = P+(Q+R)。

6数乘操作满足结合律。对于任意的实数a和b,以及向量空间V中的元素P,(ab)P = a(bP)。

7数乘操作对于向量加法满足分配律。对于任意的实数a和向量空间V中的任意元素P和Q,

a( P + Q ) = aP + aQ。

8系数加法对于数乘操作满足分配律。对于任意的实数a和b以及V中的任意向量P,

( a + b ) P = aP + bP。

定理1.11对于一组向量{ e1, e2 ,........,en },如果不存在这样一组实数a1,a2,........,an,其中

至少有一个ai不为零,使得下式成立

a1e1 + a2e2 + .........+anen = 0我给出这个公式的证明

如果是线性关系

则有一下图




aes android 向量 向量ap=xab+yac_aes android 向量_08

如果是线性,那么图上的那些红点都是连续的。

也就是x值是相同的

所以

a1 * ( x, y1 ) + a2 * ( x, y2 ) + a3 * ( x, y3 ) = 0

定理 1.12 向量空间V的基B是一个由n个线性无关的向量组成的集合,即

B = { e1, e2, .........,en },对于向量空间V中的任意一个元素P,都存在一组实数使得。

P = a1e1 + a2e2 + .........+ anen  由上面公式推导

定理1.13 对于向量空间的基B = { e1, e2, en },如果对任意的i ≠ j都有e1· e2 = 0,

则称为正交基。

e1 · e2 = 0,   P· Q = 0  两个向量相互垂直 

定理 1.14 对于给定的两个向量 e1· e2 = 0,则e1和e2和线性无关

定理 1.15 对于每一对( i, j )有e1 · e2 = δij,则基 = { e1,e2,.........,en  }称为向量空间的正交规范基。


aes android 向量 向量ap=xab+yac_struct_09



定理1.16 ( 算法 )

正交规范化:( 自己写的 )

struct vector3
{
	float x;
	float y;
	float z;
};
vector3* _Orth( vector3* _pArray, const int _count )
{
	float p = 1;
	float _p = 1;
	vector3* pFirst = &_pArray[0];
	for( int i = 1; i != _count; ++i )
	{
		//e1·e2 = p 
		p = ( pFirst->x * _pArray[i].x + pFirst->y * _pArray[i].y + pFirst->z * _pArray[i].z );
		//p = 0 已将正交,不用执行正交化算法
		if( p == 0 )
			continue;

		//1 / ||e2||² 
		_p = 1 / ( _pArray[i].x * _pArray[i].x + _pArray[i].y * _pArray[i].y + _pArray[i].z * _pArray[i].z );

		//(e1·e2)·e1
		_pArray[i].x *= p;
		_pArray[i].y *= p;
		_pArray[i].z *= p;

		//[(e1·e2)·e1] * ( 1 / ||e2||² )
		_pArray[i].x *= _p;
		_pArray[i].y *= _p;
		_pArray[i].z *= _p;

		//e1 - [(e1·e2)·e1] * ( 1 / ||e2||² )
		_pArray[i].x = pFirst->x - _pArray[i].x; 
		_pArray[i].y = pFirst->y - _pArray[i].y;
		_pArray[i].z = pFirst->z - _pArray[i].z;
		//cout<<_pArray[i].x<<" "<<_pArray[i].y<<" "<<_pArray[i].z<<endl;
	}
	return _pArray;
  }