本文转自头条号 媒体精选
先说答案:行列式是线性变换的伸缩因子。
理解行列式一定要从线性变换出发去理解,直接去理解它的代数形式是没有意义的。
这篇文章的结构是:
1、线性变换的几何直观
2、实现线性变换的矩阵
3、行列式
1.线性变换的几何直观
线性变换的几何直观有三个要点:
(1)变换前是直线的,变换后依然是直线
(2)直线比例保持不变
(3)变换前是原点的,变换后依然是原点
比如说旋转:
data:image/s3,"s3://crabby-images/9f76b/9f76b640b1da1aa59bb20993ea508f6c4ff26c1a" alt="1548126543457034962.png image.png"
data:image/s3,"s3://crabby-images/35a01/35a0196d246d8adcf9cb5c6c5231575fcbfc4ef0" alt="1548126566973042437.png image.png"
比如说推移:
data:image/s3,"s3://crabby-images/10173/101738310f259c90f7f8a43f53b7f0d950cc248e" alt="1548126589363093138.png image.png"
data:image/s3,"s3://crabby-images/2fd30/2fd307f7e400c0fe8155af4f661adaa3e96bc1b7" alt="1548126623738009195.png image.png"
这两个叠加也是线性变换:
zz
自己动手试一下(观察下是否符合之前的三个要求):
data:image/s3,"s3://crabby-images/852d1/852d117afe065259baef4cfe3ffbde417343ece1" alt="1548126686629059059.png image.png"
2 实现线性变换的矩阵
矩阵可以讲的东西非常多,我这里通过一个具体的例子来展示下矩阵是如何完成线性变换的。
data:image/s3,"s3://crabby-images/f889a/f889acb58159204ab36cbff10875b7a5764a27d7" alt="1548126793988023000.png image.png"
data:image/s3,"s3://crabby-images/cf8c9/cf8c9091f988ae4102807ef7f8edf913a14062e7" alt="1548126805832081687.png image.png"
data:image/s3,"s3://crabby-images/8f964/8f964035f3b359f4722deaace46491eddf2716d7" alt="1548126834504009084.png image.png"
我把基画出来的原因是因为矩阵变换的其实是基。
举例子来看看,比如旋转(旋转矩阵
):
data:image/s3,"s3://crabby-images/b0a37/b0a37c67902fb0d6a99e531df50fa3cd541e0794" alt="1548126957191018440.png image.png"
如果要说详细点,实际上:
data:image/s3,"s3://crabby-images/de6a5/de6a5643568bfa51588a45973b0f490b492d9c07" alt="1548126942207018357.png image.png"
我们只需要旋转基,就可以完成正方形的旋转:
data:image/s3,"s3://crabby-images/71df1/71df197e70f2f0610109a09fc1202e8d3992889f" alt="1548126981379051320.png image.png"
下面我们看看正方形的旋转过程中,旋转矩阵和基是怎样变化的(为了方便观察旋转,我标记出一个顶点):
data:image/s3,"s3://crabby-images/79f96/79f963c9b0c38781d9ad4ef5157a51a609c84e28" alt="1548127069285083155.png image.png"
再给一个例子,看看推移是怎么改变基的:
data:image/s3,"s3://crabby-images/cb112/cb11293f235616ec74b3734311757220ad4de4ce" alt="1548127083519092220.png image.png"
3 行列式
3.1 行列式是线性变换的伸缩因子
我们还是拿旋转矩阵来举例子:
data:image/s3,"s3://crabby-images/f54a6/f54a6e4bc0688c5c3d60e0cf1d63364093292cb1" alt="1548127107441085814.png image.png"
什么意思?我们来看看:
data:image/s3,"s3://crabby-images/be934/be9344474462b0f538ea844a98fadd3858e02de1" alt="1548127144473014728.png image.png"
data:image/s3,"s3://crabby-images/4c689/4c6897276e0c747dccca422a29e9adf7cdb99ad7" alt="1548127161879024128.png image.png"
在继续往下面讲之前,我设计了一个动画,让你来感受一下,变换矩阵的行列式由正到负,线性变换会怎样进行(我把基也标注出来):
data:image/s3,"s3://crabby-images/03c06/03c068621f826c4a57703455371460a6483767ac" alt="1548127187285093254.png image.png"
掌握了行列式是线性变换的伸缩因子这一点之后,我们就很容易理解各种行列式的值与线性变换的关系。
3.2 行列式>0
行列式>1,很显然对于图形有放大的作用:
data:image/s3,"s3://crabby-images/f4878/f4878e9b69f3387d2e8028aff6b8c30cf51dab39" alt="1548127213473043007.png image.png"
行列式=1,图形的大小不会变换:
data:image/s3,"s3://crabby-images/a8398/a839826b3091e294c9c23e3f958ffa2199d69cf0" alt="1548127246160082540.png image.png"
0<行列式<1,很显然对于图形有缩小的作用:
data:image/s3,"s3://crabby-images/18f00/18f00d003f2f042e075ec021692032a3e5a269bc" alt="1548127258582052635.png image.png"
3.3 行列式=0
行列式等于0,有一个重要的结论是,矩阵不可逆。这点也很好理解。
先看看什么是可逆。原始的图形是这个样子:
data:image/s3,"s3://crabby-images/0bdfd/0bdfd4e723a7ad42f1613c4f38ad84a3d24dbf43" alt="1548127275457076079.png image.png"
通过旋转矩阵,逆时针旋转 45 度:
data:image/s3,"s3://crabby-images/34967/34967ee204940276bc1eee49695fefa7afbb06f6" alt="1548127298566095237.png image.png"
再通过另外一个旋转矩阵,顺时针旋转 45 度:
data:image/s3,"s3://crabby-images/c0c20/c0c200b23a0d294e00473935b7b0fd6dc71671b2" alt="1548127312738017666.png image.png"
看起来这个正方形就像没有变换过一样,因此
data:image/s3,"s3://crabby-images/7ec22/7ec22d0034283a0234496a140ce94bec35cbaacd" alt="1548127333582027491.png image.png"
和
data:image/s3,"s3://crabby-images/67471/674713603f19bbeb011e2ef7584b9b883b664be6" alt="1548127345238019813.png image.png"
互为逆矩阵。
有的线性变换是可逆的,有的不行,比如行列式=0这样的线性变换就是不可逆的。从图像上看,图形会缩成一点:
data:image/s3,"s3://crabby-images/b5532/b55320d6a9f872abae72dd9f846b0b0c283984d5" alt="1548127364191014962.png image.png"
或者缩成一条直线:
data:image/s3,"s3://crabby-images/f9576/f9576d17eceb2061faa29f439af6e2ac58d35b25" alt="1548127379973021578.png image.png"
没有矩阵可以把它们恢复成原来的样子。
这就好比摔碎的鸡蛋、泼出去的水、破了的镜子:
data:image/s3,"s3://crabby-images/ad231/ad2317c4b16bfd6d59166e210e967f64f6f5a4bf" alt="1548127395379017172.png image.png"
所谓覆水难收、破镜难圆就是这个意思。
3.4 行列式<0
原始图像是这样的:
data:image/s3,"s3://crabby-images/04c1e/04c1ea5e295c3a7505fc0780baf3f4d6476899d1" alt="1548127414348073140.png image.png"
被行列式<0的矩阵线性变换后是这样的:
data:image/s3,"s3://crabby-images/737c9/737c9c82ac2101bcfc222b91820a0d1de9c34c2b" alt="1548127435426000821.png image.png"
行列式<0,其实就是改变了基的“左右手法则”。
4 推论
知道了行列式的意义,我们就很容易知道,为什么说:
data:image/s3,"s3://crabby-images/613dc/613dc0f0a8fa10c3a8432274737cd15a01f230af" alt="1548127457691098881.png image.png"
我们也很容易知道,为什么说:
data:image/s3,"s3://crabby-images/15942/159429eb0f33eea12e83d4bde07e4de8aabdf481" alt="1548127471363012636.png image.png"
这是因为:
data:image/s3,"s3://crabby-images/d0695/d06953646d4ecdfe1203b2049f8d0bca36498a28" alt="1548127484707035297.png image.png"
我们也很容易知道,为什么说三阶矩阵的行列式是列组成的平行六面体的体积。