【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))
相关推荐
大数据魔法师1 小时前
Streamlit(二十三)- 教程(二)- 动态导航
python·web
心中有国也有家4 小时前
GE图引擎深度解析——CANN的计算图优化与执行引擎
人工智能·pytorch·python·学习·numpy
卷毛的技术笔记5 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
编程大师哥5 小时前
匿名函数 lambda + 高阶函数
java·python·算法
isyangli_blog5 小时前
OpenDayLight (Carbon 版本) 启动与组件安装
开发语言·php
vb2008115 小时前
FastAPI APIRouter
开发语言·python
Benszen5 小时前
KVM虚拟化解决方案
开发语言·perl
会编程的土豆5 小时前
Go 语言反射(Reflection)详解
开发语言·后端·golang
東雪木5 小时前
多线程与并发编程 专属复习笔记
java·开发语言·笔记·java面试
adrninistrat0r5 小时前
Java调用链MCP分析工具
java·python·ai编程