python之拟合的实现

作者:your_answer 时间:2021-09-16 19:22:12 

一、多项式拟合

多项式拟合的话,用的的是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+1
x=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 np
from matplotlib import pyplot as plt

def f(x):
return x**2+1
def f_fit(x,y_fit):
a,b,c=y_fit.tolist()
return a*x**2+b*x+c
x=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

python之拟合的实现

拟合效果看起来还是不错的。

二、各种函数的拟合

一般来说,多项式的拟合就能拟合很多函数了,比如指数函数,取对数就能化为多项式函数,甚至是一次多项式函数。可是,那些三角函数之类的复杂函数不能化为多项式去拟合,怎么办呢?要用到scipy.optimize的curve_fit函数了。

直接贴代码:


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

def f(x):
return 2*np.sin(x)+3
def f_fit(x,a,b):
return a*np.sin(x)+b
def f_show(x,p_fit):
a,b=p_fit.tolist()
return a*np.sin(x)+b
x=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]]

python之拟合的实现

使用方法基础的就是这样了。然后更多详细的参数的使用就是要看官网了。

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

来源:https://blog.csdn.net/your_answer/article/details/79195428

标签:python,拟合
0
投稿

猜你喜欢

  • 如何利用Python获取鼠标的实时位置

    2022-08-11 07:00:33
  • 微信小程序之数据缓存的实例详解

    2024-04-19 09:49:53
  • Python时间戳与时间字符串互相转换实例代码

    2022-09-04 23:39:25
  • 交互设计实用指南系列(7)–避免迷路

    2010-01-23 09:52:00
  • 使用Pytorch构建第一个神经网络模型 附案例实战

    2023-10-13 14:40:30
  • 将图片保存到mysql数据库并展示在前端页面的实现代码

    2024-01-27 05:37:22
  • Python字符串字母大小写转换的各种情况详析

    2023-11-23 07:35:41
  • MediaPipe API实现骨骼识别功能分步讲解流程

    2022-06-17 05:41:10
  • 利用Python实现自动工作汇报的脚本分享

    2022-05-31 10:55:37
  • MSSQL2005在networkservice权限运行附加数据库报(Microsoft SQL Server,错误: 5120)

    2024-01-23 00:09:51
  • Python实现的简单hangman游戏实例

    2021-04-11 19:26:47
  • 如何把数据库记录显示到列表框里去?

    2009-11-06 13:48:00
  • 使用SqlServer CTE递归查询处理树、图和层次结构

    2024-01-16 07:35:42
  • 30秒学会30个超实用Python代码片段【收藏版】

    2021-08-04 17:13:32
  • Python pandas之多级索引取值详解

    2022-05-09 14:12:31
  • chatGPT使用及注册过程中常见的一些错误解决方法(所有报错汇总)

    2023-03-02 22:27:23
  • pytorch 实现情感分类问题小结

    2022-11-06 12:21:00
  • python中base64编码简介

    2023-09-21 20:26:12
  • Python3.5常见内置方法参数用法实例详解

    2023-02-24 21:38:38
  • Go for-range 的 value值地址每次都一样的原因解析

    2023-09-23 12:59:20
  • asp之家 网络编程 m.aspxhome.com