查看“︁线性方程组”︁的源代码
←
线性方程组
跳转到导航
跳转到搜索
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
{{NoteTA |G1 = Math }} {{线性代数}} [[File:Secretsharing-3-point.png|thumb|right|三變量的線性系統確定了一組[[平面 (数学)|平面]]。交點就是解。]] '''线性方程组'''是数学[[方程组]]的一种,它符合以下的形式: :<math> \begin{cases}a_{1,1}x_{1} + a_{1,2}x_{2} + \cdots + a_{1,n}x_{n}= b_{1} \\ a_{2,1}x_{1} + a_{2,2}x_{2} + \cdots + a_{2,n}x_{n}= b_{2} \\ \vdots \quad \quad \quad \vdots \\ a_{m,1}x_{1} + a_{m,2}x_{2} + \cdots + a_{m,n}x_{n}= b_{m} \end{cases}</math> 其中的<math>a_{1,1}, \, a_{1,2}</math>以及<math>b_{1}, \, b_{2}</math>等等是已知的常数,而<math>x_{1}, \, x_{2}</math>等等则是要求的未知数。 如果用[[线性代数]]中的概念来表达,则线性方程组可以写成: :<math>\mathbf{A} \mathbf{x} = \mathbf{b}</math> 這裡的<math>\mathbf A</math>是<math>m\times n</math>[[矩陣]],<math>\mathbf x</math>是含有<math>n</math>个元素[[向量|列向量]],<math>\mathbf b</math>是含有<math>m</math>个元素列向量。 : <math> \mathbf A= \begin{bmatrix} a_{1,1} & a_{1,2} & \cdots & a_{1,n} \\ a_{2,1} & a_{2,2} & \cdots & a_{2,n} \\ \vdots & \vdots & \ddots & \vdots \\ a_{m,1} & a_{m,2} & \cdots & a_{m,n} \end{bmatrix},\quad \mathbf{x}= \begin{bmatrix} x_1 \\ x_2 \\ \vdots \\ x_n \end{bmatrix},\quad \mathbf{b}= \begin{bmatrix} b_1 \\ b_2 \\ \vdots \\ b_m \end{bmatrix} </math> 这是线性方程组的另一种记录方法。在已知矩阵<math>\mathbf A</math>和向量<math>\mathbf{b}</math>的情况求得未知向量<math>\mathbf{x}</math>是[[线性代数]]的基本问题之一。 == 例子 == 以下是一个由两个方程构成的线性方程组: :<math> \begin{cases}3x_{1} + 5x_{2} = 4 \\ x_{1} + 2x_{2} = 1 \end{cases}</math> 方程组中有两个未知数。以[[矩阵]]表示,这个方程组可以记录为: : <math> \begin{bmatrix} 3 & 5\\ 1 & 2 \end{bmatrix} \cdot \begin{bmatrix} x_1 \\ x_2 \end{bmatrix} = \begin{bmatrix} 4 \\ 1 \end{bmatrix} </math> 这个线性方程组有一组解:<math>x_1 = 3, \, x_2 = -1 </math>。可以直接验证: :<math> \begin{cases}3 \times 3 + 5 \times (-1) = 9 - 5 = 4 \\ 3 + 2 \times (-1) = 3 -2 = 1 \end{cases}</math> 可以证明,这组解也是方程组唯一的解。 不是所有的线性方程组都有解。以下是一个没有解的例子: :<math> \begin{cases}x_{1} + x_{2} = 2\\ 2x_{1} + 2x_{2} = 1 \end{cases}</math> 显然,如果有<math>x_1</math>和<math>x_2 </math>满足了第一行的式子的话,它们的和等于2。而第二行则要求它们的和等于0.5,这不可能。 也有的线性方程组有不止一组解。例如: :<math> \begin{cases}x_{1} + x_{2} = 2 \end{cases}</math> <math>x_1 = 1, \, x_2 = 1 </math>是一组解,而<math>x_1 = 3, \, x_2 = -1 </math>也是一组解。事实上,解的个数有无限个。 == 线性方程组的解 == [[File:Intersecting Lines.svg|thumb|right|方程组的解是所有直线的公共点]] 如果有一组数<math>x_1, x_2, \cdots, x_n</math>使得方程组的等号都成立,那么这组数就叫做方程组的解。一个线性方程组的所有的解的[[集合 (数学)|集合]]会被简称为'''解集'''。根据解的存在情况,线性方程组可以分为三类: * 有唯一解的恰定方程组, * 解不存在的超定方程组, * 有无穷多解的欠定方程组(也被通俗地称为不定方程组)。 === 几何解释 === 当未知数只有两个(''x''和''y'')的时候,方程组里面的每一个方程可以看成'''Oxy'''[[平面 (数学)|平面]](正交直角坐标系)上的一条[[直线]]的方程。直线上的[[点]]的坐标就是满足这个方程的一组数。从这个角度看来,方程组的解就是所有这种直线的[[交点|公共点]]。而若干条直线的公共部分要么是一条直线,要么是一个点,要么是[[空集]],因此对应的,线性方程组的解要么有无穷个,要么恰好有一个,要么不存在。 如果未知数有三个,那么每一个方程则代表了[[三维空间]]里面的一个平面,而方程组的解集也就是一些平面的共同部分。所有解的集合可以对应一个平面,一条直线,一个点或空集。 这个问题的一般情况可以从线性空间的角度去分析,即我们可以将线性方程组的求解问题看成向量<math>\mathbf{b}</math>在矩阵<math>\mathbf A</math>所张成的[[线性空间]]里面的投影的问题。未知数的个数如果是一般的''n''个的话,可以想象每个方程代表了[[N维空间|'''n'''维空间]]里面的一个[[超平面]]。而方程组的解就是所有超平面的公共点。 === 齐次线性方程组 === 齐次的线性方程组是指向量<math>\mathbf{b}=\mathbf 0</math>的情况。这时候方程变成: <center><math>\mathbf A \mathbf{x}=\mathbf 0</math></center> 这个方程肯定会有一组解:<math>\mathbf{x}=\mathbf 0</math>。实际上,方程的解就是矩阵<math>\mathbf A</math>对应的[[线性变换]]的[[零空间]]。一般来说,当方程的个数小于未知数的个数时,方程组会有除<math>\mathbf{x}=\mathbf 0</math>以外的解。当方程组个数变多时,则要看其中“有效”的方程的个数。有时候某一个方程可以表示成另外几个方程的线性组合。比如方程组: <center><math> \begin{cases}3x_{1} + x_{2} + 2 x_{3} = 0 \\ x_{1} - x_{2} + 4 x_{3} = 0\\ 2x_{1} + 3x_{3} = 0 \end{cases}</math></center> 之中,第三个方程就可以表示为前两个方程的线性组合: <center><math> 2x_{1} + 3x_{3} = \frac{1}{2}(3x_{1} + x_{2} + 2 x_{3}) + \frac{1}{2}(x_{1} - x_{2} + 4 x_{3})</math></center> 这时第三个方程组就可以不必考虑了。用线性代数的词汇表达,“有效”的方程的个数就是矩阵<math>\mathbf A</math>中线性无关的行向量的个数,或者说行向量线性张成的空间的维数。这个数也被称为[[矩阵的秩]]。当矩阵<math>\mathbf A</math>的秩<math>r</math>小于未知数的个数<math>n</math>时,方程组的解会有无穷多个,构成一个<math>n-r</math>维的线性空间。而当<math>r</math>等于未知数的个数<math>n</math>时,方程组有唯一零解,<math>r</math>不可能大于<math>n</math>。 === 松弛求解 === 在实验数据处理和曲线拟合问题中,求解超定方程组非常普遍。这时常常需要退一步,将线性方程组的求解问题改变为求最小误差的问题。形象的说,就是在无法完全满足给定的这些条件的情况下,求一个最接近的解。比较常用的方法是[[最小二乘法]]。最小二乘法求解超定问题等价于一个[[优化问题]],或者说最小值问题,即,在不存在<math>\mathbf{x}</math>使得<math>\mathbf{b} -\mathbf A \mathbf{x} = \mathbf 0</math>的情况下,我们试图找到这样的<math>\mathbf{x}</math>使得<math>\left| \mathbf{b} - \mathbf A \mathbf{x} \right|</math>最小,其中<math>\left| \cdot \right|</math>表示[[范数]]。 == 求解 == === 克莱姆法则 === 基于线性方程组的解空间理论,线性方程组有唯一解当且仅当有效方程数等于未知数的个数。这时,可以运用各种方法具体求出唯一存在的解。[[克萊姆法則]]是一种求解'''线性方程组'''的方法,大多数[[线性代数]]教材都会提到。例如对于如下的线性方程组: <center><math>\begin{cases}a_1 x + b_1 y = c_1 \\ a_2 x + b_2 y = c_2 \end{cases}</math></center> 运用克莱姆法则,这个方程组的解可以如下: <center><math>x = \frac{D_x}{D}, \qquad y = \frac{D_y}{D}</math></center> 其中,<math>D_x, D_y, D</math>分别是如下三个[[行列式]]: <center><math> D = \left| \begin{matrix} a_1 & b_1 \\ a_2 & b_2 \end{matrix} \right| , </math> <math> D_x = \left| \begin{matrix} c_1 & b_1 \\ c_2 & b_2 \end{matrix} \right| , </math> <math> D_y = \left| \begin{matrix} a_1 & c_1 \\ a_2 & c_2 \end{matrix} \right| </math></center> 对于更一般的情况: :<math>\mathbf{A} \mathbf{x} = \mathbf{b}</math> 解可以由同样的公式给出: <center><math>\begin{cases}x_1 = \frac{D_1}{D} \\ x_2 = \frac{D_2}{D} \\ \vdots \qquad \vdots \\ x_n = \frac{D_n}{D}\end{cases}</math></center> 其中的 :<math> D = \det (\mathbf A) </math> :<math> \forall 1 \leqslant i \leqslant n, \, \, D_i = \det (\mathbf{A_i}) </math> <math>\mathbf{A_i}</math>是将矩阵<math>\mathbf A</math>的第''i''纵列换成向量'''b'''之后得到的矩阵。 可以看出,这些表达式只有在<math> D = \det (\mathbf A) </math>存在并且不等于0的时候才是有意义的,这点只有在有效方程数等于未知数的个数的时候才能得到保证。 === 数值方法 === 在实际运算中,当矩阵的维数较高时,计算[[行列式]]是非常繁複的。也就是说,计算行列式的[[计算复杂度]]随维数的增长非常快,对于一个<math>n \times n</math>的矩阵,用初等的方法计算其行列式,需要的计算时间是<math>O(n!)</math>(n的阶乘)。因此,克莱姆法则在現實問題求解幾乎不會被采用,而其重要性在于證明某些線性問題的解答會自然而然是整數解答,因而存在有效率的解法。換言之,克萊姆法則的重要性是在於理論證明的應用,而非問題的實際求解。 经典的求解线性方程组的方法一般分为两类:直接法和迭代法。前者例如[[高斯消去法]], [[LU分解]]等,后者的例子包括[[共轭梯度法]]等。这些方法的计算复杂度在可以接受的范围内,因此被广泛采用。例如,高斯消去法的复杂度为<math>O(n^3)</math> 一般来说,直接法对于阶数比较低的方程组(少于20000至30000个未知数)比较有效;而后者对于比较大的方程组更有效。在实际计算中,几十万甚至几百万个未知数的方程组并不少见。在这些情况下,迭代法有无可比拟的优势。另外,使用迭代法可以根据不同的精度要求选择终止时间,因此比较灵活。在问题特别大的时候,计算机内存可能无法容纳被操作的矩阵,这给直接法带来很大的挑战。而对于迭代法,则可以将矩阵的某一部分读入内存进行操作,然后再操作另外部分。 == 应用 == 现实中的问题大多数是连续的,例如工程中求解结构受力后的变形,[[空气动力学]]中计算机翼周围的流场,气象预报中计算大气的流动。这些现象大多是用若干个[[微分方程]]描述。用[[数值方法]]求解微分方程(组),不论是[[差分方法]]还是[[有限元方法]],通常都是通过对微分方程(连续的问题,未知数的维数是无限的)进行离散,得到线性方程组(离散问题,因为未知数的维数是有限的)。因此线性方程组的求解在科学与工程中的应用非常广泛。 许多具体的应用会得到结构比较特别的线性方程组,比如用差分方法和有限元方法离散微分方程后通常会得到三对角或五对角的方程组,网络问题有时会得到对称的线性方程组(<math>\mathbf A = \mathbf A^T</math>),因此除了通用的线性方程组求解器,在一些专业领域,研究人员们也开发了适用于特定问题的求解器,比如适用于[[稀疏矩阵]]的求解器,适用于三对角矩阵的求解器,适用于对称矩阵的求解器等。 == 相关软件 == 由于线性方程组的求解是一个非常普遍的问题,在多年的科学与工程实践中,科学家和工程师们积累很多高效率的线性方程组求解器,例如:LAPACK、BLAS等。这些软件中,许多可以可以在[http://www.netlib.org NetLib] {{Wayback|url=http://www.netlib.org/ |date=20071024041352 }}免费获得。LAPACK和BLAS在大多数[[Linux]]的发行版本中都已经预装。目前LAPACK有[[Fortran]](包括90和77版本)、C、[[C++]]等几个语言的版本。利用LAPACK和BLAS中的子程序,[http://www.mathworks.com Matlab] {{Wayback|url=http://www.mathworks.com/ |date=20210505033254 }}对这些线性方程组求解器进行封装。用户不需要选择求解器的类型和问题的类型,[[Matlab]]可以根据对矩阵的分析自动选择合适的求解器。 == 其他方法与软件 == 上面讲的是线性方程组的数值解法。对于比较小的线性方程组,求得符号解是可能的。常用的软件有Mathematica, Maple等。在某些领域的研究中,这种需要并且可能求符号解(精确解)的情况偶尔会遇到。未知数的个数一般限制在几十个左右。显然,符号解在对于实际中遇到的有几百万个未知数的问题是无能为力的,比如,大型结构,天气预报,湍流模拟等问题中得到的线性方程组。 == 参见 == *[[方程]] *[[不定方程]] *[[鸡兔同笼]] *[[对角化]] *[[逆矩阵]] *[[微分方程]] == 参考文献 == <div class="references-small"> <references /> * https://web.archive.org/web/20070208024707/http://www.okc.cc.ok.us/maustin/Cramers_Rule/Cramer%27s%20Rule.htm * http://www.netlib.org/lapack/ {{Wayback|url=http://www.netlib.org/lapack/ |date=20110224085358 }} * http://www.mathworks.com {{Wayback|url=http://www.mathworks.com/ |date=20210505033254 }} </div> == 外部連結 == * {{en}}[http://www.mathway.com/ Mathway] {{Wayback|url=http://www.mathway.com/ |date=20210325145233 }},使用電腦解決絕大部分的數學問題。 * {{En}}[http://www.idomaths.com/simeq.php Simultaneous Linear Equations Calculator] {{Wayback|url=http://www.idomaths.com/simeq.php |date=20201125073035 }},一個簡單的线性[[方程组]]求解器 {{线性代数的相关概念}} {{authority control}} [[Category:線性代數|X]] [[Category:方程]]
该页面使用的模板:
Template:Authority control
(
查看源代码
)
Template:En
(
查看源代码
)
Template:NoteTA
(
查看源代码
)
Template:Wayback
(
查看源代码
)
Template:线性代数
(
查看源代码
)
Template:线性代数的相关概念
(
查看源代码
)
返回
线性方程组
。
导航菜单
个人工具
登录
命名空间
页面
讨论
不转换
查看
阅读
查看源代码
查看历史
更多
搜索
导航
首页
最近更改
随机页面
MediaWiki帮助
特殊页面
工具
链入页面
相关更改
页面信息