矩阵行列式简明教程
moboyou 2025-04-26 18:31 32 浏览
如果你的线性代数课和我的类似,你就会学到如何通过计算行列式来描述矩阵。然而,我发现大多数课程都没有完全定义矩阵行列式到底是什么。在这次讨论中,我希望深入探讨如何计算行列式,同时也描述你正在计算的内容。
NSDT工具推荐: Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器 - REVIT导出3D模型插件 - 3D模型语义搜索引擎 - Three.js虚拟轴心开发包 - 3D模型在线减面 - STL模型在线切割
1、定义
行列式是与方阵相关的标量值。让我们看看一般情况,看看我们如何计算行列式:
我们将此表达式称为拉普拉斯展开式(Laplace Expansion)。这里有很多东西需要解开,但一旦你掌握了符号表示,它就相当简单了。它基本上是说将矩阵 A 分成越来越小的子矩阵,直到你可以相对轻松地计算出行列式。我们还通过 A 的第 i 列和第 j 列为每个后续子矩阵添加一个“权重”。我们将在 3x3 的情况下研究这个概括。但首先让我们讨论最简单的计算 - 2x2 的情况:
2x2 的情况只需找出主对角线和反对角线之间的差值。拉普拉斯展开式中的子矩阵可以简化为 2x2 的情况。但是,你也可以将子矩阵简化为 3x3 的情况:
请注意,3x3 的情况是拉普拉斯展开的直接应用。我们保持顶行固定(但可以是任何行或列),将其用作乘数,并将主矩阵简化为 2x2 子矩阵。由于我们可以轻松计算 2x2 子矩阵的行列式,因此计算变得更加简单。注意交替的正负号也很重要。这来自拉普拉斯展开中的 -1 项。我们在创建子矩阵时交替使用符号。
手动计算行列式很快就会变得不可行。想象一个 100x100 的矩阵。我们需要多次递归执行拉普拉斯展开,导致项激增。即使在较小的矩阵(例如 5x5 矩阵)中,它也很快变得平凡。但是,软件中的数值方法可以快速计算行列式,因此在大多数情况下不需要手动计算。
2、几何解释
行列式的代数解释非常适合为计算行列式提供基础。但是,它无法提供对行列式的直观理解。它使行列式看起来只是数字的乘积。
地理解释在解释行列式方面做得更好。让我们探讨 2x2 的情况:
上面是矩阵 A 的 2x2 描述。上面的平行四边形是通过认识到矩阵 A 形成两个线性映射而构建的:一个将标准基向量映射到 A 的行,另一个将标准基向量映射到 A 的列。换句话说,我们可以绘制图中所示的 A 的元素。
这使得行列式成为平行四边形的面积!那么,面积就代表了 A 变换其他面积的比例。现在我知道你在想什么了。
但行列式可以为负数。面积怎么会是负数呢?
好问题!这引出了我们的下一个讨论主题:方向。当我们将符号应用于面积时,我们就得到了一个有向面积。有向面积和面积之间的唯一区别就是符号:负向面积意味着第一和第二个向量的角度是顺时针方向而不是逆时针方向。但是,两者的面积大小是相同的。它们是具有大小和方向的类似向量。向量没有负大小;它只是具有与大小相关的方向。
好的,这描述了 2x2 的情况。那么 3x3 的情况呢?或者 NxN 的情况呢?答案是,它们是相同的概念!唯一改变的是形状。在 3x3 的情况下,它形成一个平行六面体,在 NxN 的情况下,它形成一个平行四面体。换句话说,3x3 的情况计算体积,4x4 的情况计算超体积,等等。在三维以上,它变得更加抽象,但基本原理保持不变:我们正在计算 A 变换其他物体的尺度。
3、行列式的属性
让我们回顾一下行列式的一些属性。其中许多属性可以通过上面的代数公式推导出来。我不会直接推导这些属性,但通过 2x2 的情况来验证这些属性中的每一个是一个很好的检查。
- 当两行交换时,行列式会改变符号。
- 如果两行相等,则行列式为零。
- 从一行中减去另一行的倍数会留下相同的行列式。
- 如果矩阵是奇异的,则行列式为零。
- AB 的行列式是 det(A) * det(B)
- A 的转置具有与 A 相同的行列式
4、行列式的应用
行列式有多种应用,但其中三种值得讨论。
- 奇异矩阵
确定矩阵是否非奇异(即可逆)的较简单方法之一是计算其行列式。奇异矩阵不可逆当且仅当行列式为零时。在线性代数中,知道矩阵是否可逆通常非常有益。
- 克莱默规则
有人可能会说,线性代数的主要目标是解方程:
克莱默规则(Cramer's Rule)是计算 x 的一种方法。我们将 x 的第 j 个分量定义为:
其中 B 与 A 相同,只是 a 中的第 j 个分量被向量 b 替换。虽然克莱姆法则是一种有趣的解决问题的方法,但从计算复杂性的角度来看,它效率极低。有更多更有效的算法可用于计算 x。
- 特征方程
线性代数中的特征方程是:
它用于确定矩阵 A 的特征值和特征向量。虽然特征值和特征向量有点超出了本文的讨论范围,但它们在线性代数之外的许多数学领域中都发挥着重要作用。关于行列式,请注意,我们直接计算上述表达式的行列式。我们还找到了特征值,使得表达式是一个奇异矩阵,这是它成为特征值的必要条件。
5、Python 中的行列式
如前所述,手动计算很繁琐,而且很容易出错,效率低下。Python 和 Matlab 等编程语言能够高效准确地计算行列式。让我们看一个例子:
我们可以使用拉普拉斯展开式将矩阵划分为 3x3 子矩阵,然后将其划分为 2x2 子矩阵,但请注意我们需要跟踪多少项。我们还需要确保每个项的符号与展开式保持一致。但是,如果你只需要找到行列式,还有一种更简单的方法:python!
import scipy.linalg as la
import numpy as np
A = np.array([[2,4,2,5], [1,5,2,6], [8,5,3,2], [0,1,3,6]])
det = la.det(A)
快速而简单。我们能够高效而准确地计算矩阵的行列式。4x4 矩阵相对较小,但你能想象如果我们有一个 10x10 矩阵会怎样吗?100x100 矩阵?1000x1000 矩阵?编程语言成为大多数应用程序的唯一选择。
6、结束语
行列式很难解释。学习如何计算矩阵并使用其属性来描述矩阵要容易得多。直观地了解你正在计算的内容要困难得多。希望这有助于让你获得这种直观的理解。
原文链接:矩阵行列式简明教程 - BimAnt
相关推荐
- 黄道十二宫杀手密码51年后被破解,来自两位程序员和数学家合作
-
杨净边策发自凹非寺量子位报道|公众号QbitAI黄道十二宫杀手(ZodiacKiller)可能是世界上最知名的高智商连环杀手,52年来从未被抓获。他的事迹已被改编成了多部好莱坞电影。△...
- 深入剖析MediaCodec解码器的基本原理及使用「建议新手收藏」
-
一,MediaCodec工作原理MediaCodec类Android提供的用于访问低层多媒体编/解码器接口,它是Android低层多媒体架构的一部分,通常与MediaExtractor、MediaMu...
- Retrofit WebService 实践
-
前言作为Android开发,平时和后端聊得最多的除了喝酒就是接口。常用语:Restful和WebService,前者现在聊得多,后者以前聊得多。默认含义分别为:Restful:HTTP协议...
- 建议收藏!175部4K UHD版本经典高分电影洗版参考目录(2015之前)
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:1L789近两年很多经典高分老电影陆续开始重制成4KUHD版本,虽然我早已将这些电影的BD蓝光版收入,但纠结一番后还是花了不少时间将其全部...
- 2 个月的面试亲身经历告诉大家,如何进入 BAT 等大厂?
-
这篇文章主要是从项目来讲的,所以,从以下几个方面展开。怎么介绍项目?怎么介绍项目难点与亮点?你负责的模块?怎么让面试官满意?怎么介绍项目?我在刚刚开始面试的时候,也遇到了这个问题,也是我第一个思考的问...
- 详解Android官推Kotlin-First的图片加载库
-
前言Coil是一个非常年轻的图片加载库,在2020年10月22日才发布了1.0.0版本,但却受到了Android官方的推广,在AndroidDevelopersBackst...
- webview 渲染机制:硬件加速方式渲染的Android Web
-
webview渲染是什么?webview渲染是用于展现web页面的控件;webview可以内嵌在移动端,实现前端的混合式开发,大多数混合式开发框架都是基于webview模式进行二次开发的w...
- 因为我对Handler的了解,居然直接给我加了5K
-
1Handler是什么?android提供的线程切换工具类。主要的作用是通过handler实现从子线程切换回主线程进行ui刷新操作。1.1为什么Handler能实现线程切换?在创建Handler的...
- 「经典总结」一个View,从无到有会走的三个流程,你知道吗?
-
前言一个View,从无到有会走三个流程,也就是老生常谈的measure,layout,draw三流程我们都知道Android视图是由一层一层构成的层级结构,直白点说,就是父View包含子View而子V...
- 这些垃圾代码是谁写的?哦,原来小丑竟是我自己
-
程序员是最喜欢自嘲、自黑的群体之一,比如他们常常称自己是“码农”、“程序猿”,再比如他们的工作明明是写代码、修Bug,也有人调侃说:“明明我们是修代码、写Bug!”本文整理了一些程序员“修代码、写...
- 手把手教你爬取天堂网1920*1080大图片(批量下载)——理论篇
-
/1前言/平时我们要下载图片,要要一个一个点击下载是不是觉得很麻烦?那有没有更加简便的方法呢?答案是肯定的,这里我们以天堂网为例,批量下载天堂网的图片。/2项目准备工作/首先我们第一步我们要安装...
- 音视频开发需要你懂得 ffmpeg 开源库的编码原理
-
引言音视频开发需要你懂得音视频中一些基本概念,针对编解码而言,我们必须提前懂得编解码器的一些特性,码流的结构,码流中一些重要信息如sps,pps,vps,startcode以及基本的工作原理,...
- 「8年老 Android 开发」最全最新 Android 面试题系列全家桶(带答案)
-
下面跟大家分享的这些面试题都是互联网大厂真实流出的面试内容,每个问题都附带完整详细的答案,不像网上的那些资料三教九流有的甚至还没答案,这些面试题我也是经过日积月累才整理出来的精品资料。这些面试题主要是...
- 手把手教你爬取天堂网1920*1080大图片(批量下载)——实战篇
-
/1前言/上篇文章手把手教你爬取天堂网1920*1080大图片(批量下载)——理论篇我们谈及了天堂网站图片抓取的理论,这篇文章将针对上篇文章的未尽事宜进行完善,完成图片的批量抓取。/2图片网址解...
- PHP 8.1.9 更新发布
-
CLI:修复了内置服务器通过PHP_CLI_server_WORKERS环境变量的潜在溢出。修正了GH-8952(不再可能有意关闭std句柄)。Core:修复了GH-8923的错误(Windows上的...
- 一周热门
- 最近发表
- 标签列表
-
- curseforge官网网址 (16)
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle 数据导出导入 (16)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle安装补丁 (19)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- c语言编程小知识大全 (17)
- css class选择器用法 (25)
- css样式引入 (30)
- html5和css3新特性 (19)
- css教程文字移动 (33)
- php简单源码 (36)
- php个人中心源码 (25)
- 网站管理平台php源码 (19)
- php小说爬取源码 (23)