使用numpy,scipy库用最小二乘法拟合曲线

#coding=gbk
import numpy as np
from scipy.optimize import leastsq
import pylab as pl

Yi=np.array([7.01,2.78,6.47,6.71,4.1,4.23,4.05])
xi=np.array([8.19,2.72,6.39,8.71,4.7,2.66,3.78])

def func(p,x):
	k,b=p
	return k*x+b

def error(p,x,y,s):
	print(s)
	return func(p,x)-y

 #TEST
p0=[100,2]
#print( error(p0,Xi,Yi) )
s="Test the number of iteration" #试验最小二乘法函数leastsq得调用几次error函数才能找到使得均方误差之和最小的k、b
Para=leastsq(error,p0,args=(xi,Yi,s)) #把error函数中除了p以外的参数打包到args中
k,b=Para[0]
print("k=",k,'\n',"b=",b)

###绘图,看拟合效果###
import matplotlib.pyplot as plt

plt.figure(figsize=(10,1))
plt.scatter(xi,Yi,color="red",label="Sample Point",linewidth=3) #画样本点
x=np.linspace(0,10,1000)
y=k*x+b
plt.plot(x,y,color="orange",label="Fitting Line",linewidth=2) #画拟合直线
plt.legend
plt.show()

使用scipy的leastsq()函数可以进行最小二乘法拟合

具体步骤 :

1.先引入 格式:xi=np.array([])

2.定义一个拟合的函数func()传入函数需要的参数(p:函数中的未知数,以及x),如果是一次函数就是p(p为k与b),x,return为函数计算的值

3.定义一个计算偏差的函数error 传入参数(p,x,y(实际测量值))返回y与func(p,x)的差值

4.leastsq(error,p0(初始的未知数值),(xi,yi))返回一个数组 args, args[0]就可以得到k,b

5.画图调用matplotlib.pyplot库


  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值