时间:2021-05-22
一、多项式拟合
多项式拟合的话,用的的是numpy这个库的polyfit这个函数。那么多项式拟合,最简单的当然是,一次多项式拟合了,就是线性回归。直接看代码吧
import numpy as np def linear_regression(x,y): #y=bx+a,线性回归 num=len(x) b=(np.sum(x*y)-num*np.mean(x)*np.mean(y))/(np.sum(x*x)-num*np.mean(x)**2) a=np.mean(y)-b*np.mean(x) return np.array([b,a])def f(x): return 2*x+1x=np.linspace(-5,5)y=f(x)+np.random.randn(len(x))#加入噪音y_fit=np.polyfit(x,y,1)#一次多项式拟合,也就是线性回归print(linear_regression(x,y))print(y_fit)手写线性回归我还是会的,然后我们来看下输出:
[1.9937839 1.24167225]
[1.9937839 1.24167225]
由于有random每次显示的结果都不一样,但很明显的是上下两个print是意料之中的一样,emmmmm,一次多项式拟合的源代码应该就是像我写的那样。好了,那么一次以上呢?咳咳,我数学不算太好,还是老老实实用库函数吧,顺便画下图,见识它的威力。
import numpy as npfrom matplotlib import pyplot as plt def f(x): return x**2+1def f_fit(x,y_fit): a,b,c=y_fit.tolist() return a*x**2+b*x+cx=np.linspace(-5,5)y=f(x)+np.random.randn(len(x))#加入噪音y_fit=np.polyfit(x,y,2)#二次多项式拟合y_show=np.poly1d(y_fit)#函数优美的形式print(y_show)#打印y1=f_fit(x,y_fit)plt.plot(x,f(x),'r',label='original')plt.scatter(x,y,c='g',label='before_fitting')#散点图plt.plot(x,y1,'b--',label='fitting')plt.title('polyfitting')plt.xlabel('x')plt.ylabel('y')plt.legend()#显示标签plt.show()输出:
2
1.001 x - 0.04002 x + 0.8952
拟合效果看起来还是不错的。
二、各种函数的拟合
一般来说,多项式的拟合就能拟合很多函数了,比如指数函数,取对数就能化为多项式函数,甚至是一次多项式函数。可是,那些三角函数之类的复杂函数不能化为多项式去拟合,怎么办呢?要用到scipy.optimize的curve_fit函数了。
直接贴代码:
import numpy as npfrom matplotlib import pyplot as pltfrom scipy.optimize import curve_fit def f(x): return 2*np.sin(x)+3def f_fit(x,a,b): return a*np.sin(x)+bdef f_show(x,p_fit): a,b=p_fit.tolist() return a*np.sin(x)+bx=np.linspace(-2*np.pi,2*np.pi)y=f(x)+0.5*np.random.randn(len(x))#加入了噪音p_fit,pcov=curve_fit(f_fit,x,y)#曲线拟合print(p_fit)#最优参数print(pcov)#最优参数的协方差估计矩阵y1=f_show(x,p_fit)plt.plot(x,f(x),'r',label='original')plt.scatter(x,y,c='g',label='before_fitting')#散点图plt.plot(x,y1,'b--',label='fitting')plt.xlabel('x')plt.ylabel('y')plt.legend()plt.show()输出:
[1.91267059 3.04489528]
[[ 9.06910892e-03 -1.83703696e-11]
[-1.83703696e-11 4.44386331e-03]]
使用方法基础的就是这样了。然后更多详细的参数的使用就是要看官网了。
1、https://docs.scipy.org/doc/numpy/reference/generated/numpy.polyfit.html
2、https://docs.scipy.org/doc/scipy-0.18.1/reference/generated/scipy.optimize.curve_fit.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Lasso原理Lasso与弹性拟合比较python实现importnumpyasnpimportmatplotlib.pyplotaspltfromsklear
本文实例讲述了Python图像处理之直线和曲线的拟合与绘制。分享给大家供大家参考,具体如下:在数据处理和绘图中,我们通常会遇到直线或曲线的拟合问题,python
Android动画之小球拟合动画实例实现效果:动画组成:1.通过三阶贝塞尔曲线来拟合圆,拟合系数的由来,以及怎么选控制点.2.利用画布canvas.transl
本文实例讲述了Python实现的多项式拟合功能。分享给大家供大家参考,具体如下:#-*-coding:utf-8-*-#!python2importnumpya
本文实例讲述了Python实现曲线拟合操作。分享给大家供大家参考,具体如下:这两天学习了用python来拟合曲线。一、环境配置本人比较比较懒,所以下载的全部是e