使用matplotlib进行曲线拟合

import numpy as np
import matplotlib.pyplot as plt
 
#定义x、y散点坐标
x = np.arange(3200, 35000, 3200)
num1 = [0.472,0.469,0.447,0.433,0.418,0.418,0.418,0.418,0.418,0.418]
num2 = [0.337,0.327,0.325,0.316,0.312,0.311,0.308,0.305,0.295,0.290]
y1 = np.array(num1)
y2 = np.array(num2)
 
#用3次多项式拟合
f1 = np.polyfit(x, y1, 3)
p1 = np.poly1d(f1)
print(p1)#打印出拟合函数
yvals1 = p1(x)  #拟合y值

f2 = np.polyfit(x, y2, 3)
p2 = np.poly1d(f2)
print(p2)
#也可使用yvals=np.polyval(f1, x)
yvals2 = p2(x)
 
#绘图
plot1 = plt.plot(x, y1, 's',label='original values')
plot2 = plt.plot(x, yvals1, 'r',label='polyfit values')
plot3 = plt.plot(x, y2, 's',label='original values2')
plot4 = plt.plot(x, yvals2, 'r',label='polyfit values2')


plt.xlabel('x')
plt.ylabel('y')
plt.legend(loc=2, bbox_to_anchor=(1.05,1.0),borderaxespad = 0.)
plt.title('polyfitting')
plt.savefig('nihe1.png')
plt.show()

第一种方法是使用ployfit进行曲线拟合,如上所示。

import numpy as np
import matplotlib.pyplot as plt
from scipy.optimize import curve_fit

def func(x, a, b, c):
    return a * x**2+b*x + c
 
#定义x、y散点坐标
x = np.arange(3200, 35000, 3200)
num1 = [0.472,0.469,0.447,0.433,0.418,0.418,0.418,0.418,0.418,0.418]
y1 = np.array(num1)

 
#绘图
plot1 = plt.plot(x, y1, 'ms',label='orig1')


popt, pcov = curve_fit(func, x, y1)
yy2 = [func(i, popt[0],popt[1],popt[2]) for i in x]
plt.plot(x, yy2, 'r-', label='fit')


print u'系数a:', popt[0]
print u'系数b:', popt[1]
print u'系数c:',popt[2]


plt.xlabel('x')
plt.ylabel('y')
plt.legend(loc=2, bbox_to_anchor=(1.05,1.0),borderaxespad = 0.)
plt.title('polyfitting')
plt.subplots_adjust(right=0.75)
plt.savefig('test3.png',frameon = True,figsize = (18.5,10.5),dpi = 100)
plt.show()

第二种方法是使用curve_fit进行曲线拟合,如上所示。

  • 2
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值