【python】求解线性方程

唯一解(矩阵法、solve函数)

{ 3 x + y = 9 x + 2 y = 8 \left\{ \begin{matrix} 3x+y=9 \\ x+2y=8 \end{matrix} \right. {3x+y=9x+2y=8
A x = b Ax=b Ax=b,其中 A = [ 3 1 1 2 ] A=\left[\begin{matrix} 3 & 1 \\ 1 &2 \end{matrix}\right] A=[3112], B = [ 9 8 ] B=\left[\begin{matrix} 9 \\ 8 \end{matrix}\right] B=[98],则 x = A − 1 b = [ 2 3 ] x = A^{-1}b=\left[\begin{matrix} 2 \\ 3 \end{matrix}\right] x=A−1b=[23]

可以使用np.linalg.inv(a) @ b或者np.linalg.solve(a, b)求解

python 复制代码
import numpy as np
a = np.array([[3, 1], [1, 2]])
b = np.array([[9] ,[8]])
x1 = np.linalg.inv(a) @ b  #第一种解法
#上面语句中@表示矩阵乘法
x2 = np.linalg.solve(a, b) #第二种解法

print(a);print(b)
print(np.linalg.inv(a))
print(x1); print(x2)

最小二乘解(方程数>未知数)

具体解释线性方程组的最小二乘解和最小范数解 - 杨晓东的文章 - 知乎
{ 3 x + y = 9 x + 2 y = 8 x + y = 6 \left\{ \begin{matrix} 3x+y=9 \\ x+2y=8 \\x+y=6 \end{matrix} \right. ⎩ ⎨ ⎧3x+y=9x+2y=8x+y=6

使用广义逆矩阵np.linalg.pinv(a) @ b,结果最小二乘解:[2,3.1667]

python 复制代码
import numpy as np
a = np.array([[3, 1], [1, 2], [1, 1]])
b = np.array([9, 8, 6])
x = np.linalg.pinv(a) @ b  
print(np.round(x, 4))
相关推荐
Knight_AL2 分钟前
一文讲透 Java 中transient的用处(结合 Flink 理解)
java·python·flink
阿蒙Amon3 分钟前
C#每日面试题-简述反射
开发语言·面试·c#
独行soc4 分钟前
2026年渗透测试面试题总结-5(题目+回答)
android·网络·python·安全·web安全·渗透测试
玩大数据的龙威8 分钟前
农经权二轮延包—一键出承包地块调查表
数据库·python
越甲八千8 分钟前
python socket
开发语言·python
缺点内向9 分钟前
告别“复制粘贴”:用C#和模板高效生成Word文档
开发语言·c#·word
edisao10 分钟前
【开源】轻量级 LLM 文本质检工具:精准识别核心概念缺失,支持动态别名 + 反馈闭环
大数据·开发语言·人工智能·经验分享·gpt·架构·开源
爱吃肉的鹏17 分钟前
树莓派4B安装pytorch
人工智能·pytorch·python
Leweslyh20 分钟前
【实战】如何在家定位国际空间站 (ISS)? —— 坐标转换的魔法 (例题 5.9)
开发语言·javascript·ecmascript
Sheep Shaun21 分钟前
深入理解AVL树:从概念到完整C++实现详解
服务器·开发语言·数据结构·c++·后端·算法