0

0

如何求解含两个方程、三个未知数的线性方程组

花韻仙語

花韻仙語

发布时间:2026-01-07 16:53:31

|

796人浏览过

|

来源于php中文网

原创

如何求解含两个方程、三个未知数的线性方程组

本文讲解为何无法用 np.linalg.inv() 直接求解欠定方程组(2方程3未知数),并提供正确方法:引入自由变量、参数化解析表达式,辅以 numpy 的最小二乘近似与手动通解推导。

当方程个数少于未知数个数(如本例中 2 个方程、3 个未知数)时,该系统称为欠定线性系统(underdetermined system)。此时一般不存在唯一解,而是存在无穷多解,其解集构成一条直线(或更高维流形)——在三维空间中,两个独立平面相交于一条直线。

你原始代码中的核心错误在于:

np.linalg.inv(M1).dot(v1)

M1 是一个 $2 \times 3$ 矩阵,不可逆(只有方阵才可能有逆矩阵),调用 np.linalg.inv() 会直接报错 LinAlgError: Last 2 dimensions of the array must be square。

✅ 正确思路分三步:

1. 手动消元,得到通解(推荐用于理解与精确表达)

将原方程组写为: $$ \begin{cases} 10x + 5y + 0.5z = 100 \quad\text{(1)}\ x + y + z = 100 \quad\text{(2)} \end{cases} $$

用 (2) 式解出 $x = 100 - y - z$,代入 (1): $$ 10(100 - y - z) + 5y + 0.5z = 100 \ \Rightarrow 1000 - 10y - 10z + 5y + 0.5z = 100 \ \Rightarrow -5y -9.5z = -900 \ \Rightarrow 5y = 900 - 9.5z \ \Rightarrow y = 180 - 1.9z $$

再代回得: $$ x = 100 - (180 - 1.9z) - z = -80 + 0.9z $$

因此通解为(令自由变量 $z = t \in \mathbb{R}$): $$ \boxed{ \begin{aligned} x &= -80 + 0.9t \ y &= 180 - 1.9t \ z &= t \end{aligned} } $$

例如,取 $t = 100$ 得整数解:$(x, y, z) = (10, -10, 100)$;取 $t = 80$ 得 $(x,y,z)=(−8,28,80)$,均满足原方程。

2. 使用 NumPy 求最小二乘解(当需“最优”特解时)

若你希望获得一个范数最小的解(即 $| [x,y,z]^\top |$ 最小),可用 np.linalg.lstsq:

Supercreator
Supercreator

AI视频创作编辑器,几分钟内从构思到创作。

下载
import numpy as np

A = np.array([[10., 5., 0.5],
              [1.,  1., 1. ]])
b = np.array([100., 100.])

# 求最小二乘解(自动处理欠定情形)
x_min, residuals, rank, s = np.linalg.lstsq(A, b, rcond=None)
print("最小范数解:", x_min)  # 输出类似 [ -7.14285714  28.57142857  78.57142857]

该解是所有无穷解中欧氏长度最短的一个,数学上等于 $A^+ b$($A^+$ 为 Moore–Penrose 伪逆)。

3. 验证解的正确性(关键步骤)

无论采用哪种方法,务必代入原方程验证:

x, y, z = x_min  # 或任一通解如 t=80 对应的 (-8, 28, 80)
print("Eq1:", 10*x + 5*y + 0.5*z)  # 应 ≈ 100
print("Eq2:", x + y + z)           # 应 ≈ 100

⚠️ 注意事项:

  • np.linalg.solve() 仅适用于方阵且满秩的系数矩阵,不适用于本例;
  • for 循环暴力枚举(如遍历 $z$ 从 0 到 100)虽可行,但效率低、不具通用性,仅适合教学演示小范围整数解搜索;
  • 实际应用中,若问题隐含约束(如 $x,y,z \geq 0$ 且为整数),则需结合整数规划枚举+过滤,而非纯线性代数。

总结:面对欠定系统,首要任务是识别其结构,选择解析通解(最准确)、最小二乘解(最“中心”)或带约束的特解(最实用),而非强行套用方阵求解工具

相关专题

更多
php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

14

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

5

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

19

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

105

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.9万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号