python拟合直线方程_Python数值计算——Scipy库的应用

本文介绍了Python的Scipy库在数值计算中的应用,包括非线性方程组求解、最小二乘拟合、线性函数和指数函数的拟合、解线性方程组以及求解常微分方程组。通过实例展示了optimize.leastsq、curve_fit函数以及odeint函数的使用方法,强调了Scipy库在数据分析和科学计算中的强大功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

87fdc0ea8b86cd82e48ac754259ea3f1.png

Scipy在 Numpy的基础上增加了众多的数学计算、利学计算以及工程计算中常用的模块, 例如线性代数、常微分方程数值求解、信号处理、图像处理、稀疏矩阵等。今天我们用几个数值计算常用的算法来体验一下python的Scipy库强大之处。

  1. 拟合与优化一optimize

非线性方程组求解

且看如下图所示的一组非线性方程,手算求解的估计要费九牛二虎之力,我们看一下如何利用Scipy库里面的优化函数进行求解,这段代码大家可以修改之后用于自己需要求解非线性方程组:

c6f188c4483a4919b1f37bc6dd29d589.png
from math import sin, cos 
from scipy import optimize
####定义非线性方程组
def f(x): 
   #######tolist的作用是将list转化为浮点型的list
    x0, xl, x2 = x.tolist() 
    return [
            5*xl+3,
            4*x0*x0 - 2*sin(xl*x2), 
            xl*x2 - 1.5
            ]
# f 计算方程组的误差,[ 1 ,1 ,1 ]是未知数的初始值 
result = optimize.fsolve(f, [1,1,1])
######输出x0 x1 x2
print (result)
#####检验求解的结果的正确性
print (f(result))
 

最小二乘拟合

最小二乘法在数据分析中非常常见,假如我们知道一组数据他们符合某种函数关系,我们可以通过最小二乘法去确定该函数中的某些参数,例如下面的一组数据,我们假设其符合Y=ax+b这种线性函数关系,利用最小二乘法我们可以确定a与b的值,我们可以调用了Scipy库中的 optimize.leastsq函数,除了这个函数以外还有专门的curve_fit函数curve_fit函数更加直白一点,curve_fit你只需要定义你需要拟合的函数,而optimize.leastsq你需要定义的是残差函数。下面的两段代码分别采用optimize.leastsq函数和curve_fit函数拟合。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值