Python线性拟合实现函数与用法示例
2018-12-13 20:03
731 查看
本文实例讲述了Python线性拟合实现函数与用法。分享给大家供大家参考,具体如下:
1. 参考别人写的:
#-*- coding:utf-8 -*- import math import matplotlib.pyplot as plt def linefit(x , y): N = float(len(x)) sx,sy,sxx,syy,sxy=0,0,0,0,0 for i in range(0,int(N)): sx += x[i] sy += y[i] sxx += x[i]*x[i] syy += y[i]*y[i] sxy += x[i]*y[i] a = (sy*sx/N -sxy)/( sx*sx/N -sxx) b = (sy - a*sx)/N r = abs(sy*sx/N-sxy)/math.sqrt((sxx-sx*sx/N)*(syy-sy*sy/N)) return a,b,r if __name__ == '__main__': x=[ 1 ,2 ,3 ,4 ,5 ,6] y=[ 2.5 ,3.51 ,4.45 ,5.52 ,6.47 ,7.51] a,b,r=linefit(x,y) print("X=",x) print("Y=",y) print("拟合结果: y = %10.5f x + %10.5f , r=%10.5f" % (a,b,r) ) plt.plot(x, y, "r:", linewidth=2) plt.grid(True) plt.show()
显示图像如下:
2. 不用拟合,直接显示一个一元函数
#-*- coding:utf-8 -*- import numpy as np import matplotlib.pyplot as plt import math f = lambda x:5*x+4 tx = np.linspace(0,10,50) print tx plt.plot(tx, f(tx), "r-", linewidth=2) plt.grid(True) plt.show()
运行结果:
PS:这里再为大家推荐两款相似的在线工具供大家参考:
在线多项式曲线及曲线函数拟合工具:
http://tools.jb51.net/jisuanqi/create_fun
在线绘制多项式/函数曲线图形工具:
http://tools.jb51.net/jisuanqi/fun_draw
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- Python中split()函数的用法及实际使用示例
- Python实现对一个函数应用多个装饰器的方法示例
- Python3基础 yield生成器 在函数中的用法 示例
- Python常见工厂函数用法示例
- Python常见字典内建函数用法示例
- Python常见内置高效率函数用法示例
- Python map和reduce函数用法示例
- 使用python实现strcmp函数功能示例
- Python实现判断字符串中包含某个字符的判断函数示例
- Python map和reduce函数用法示例
- Python 实现异步调用函数的示例讲解
- Python中偏函数用法示例
- Python常用字符串替换函数strip、replace及sub用法示例
- Python中shutil模块的常用文件操作函数用法示例
- python中实现延时回调普通函数示例代码
- Python闭包之返回函数的函数用法示例
- python里面的join函数用法及简单示例
- Python中pow()和math.pow()函数用法示例
- google authenticator算法TOTP的python实现(函数与模块示例)
- 利用 Python 实现多线程多任务提交 - matlab 函数示例