本文实例讲述了Python实现曲线拟合操作。分享给大家供大家参考,具体如下:
这两天学习了用python来拟合曲线。
本人比较比较懒,所以下载的全部是exe文件来安装,安装按照顺利来安装。自动会找到python的安装路径,一直点下一步就行。还有其他的两种安装方式:一种是解压,一种是pip。我没有尝试,就不乱说八道了。
没有ArcGIS 环境的,可以不看下面这段话了。
在配置环境时遇见一个小波折,就是原先电脑装过ArcGIS10.2 ,所以其会默认安装python2.7,而且python是32位的。且其目录为C:\Python27\ArcGIS10.2,所以引用环境变量时,要注意。并且在其引用的工具包中本身包含numpy,matplotlib的包。还是很方便的。但是因为之前想用PyQT来做曲线拟合的界面,安装QT时总是失败,所以最后放弃使用这个。在安装新的python时注意要把路径写到上面这个路径前面,意思就是说在安装上面的包的时候会找默认python路径。我新安装python路径为C:\Python2,要不然就会找到ArcGIS那个python包路径下了。
1. 安装包
python2.7 (32位)https://www.python.org/downloads/
numpy-1.8.1-win32-superpack-python2.7
scipy-0.15.1-win32-superpack-python2.7
matplotlib-1.3.1.win32-py2.7
安装过程中遇见的问题
提示
numpy是Python的一种开源的数值计算扩展,数学计算很方便。
scipy是一款方便、易于使用、专为科学和工程设计的Python工具包.它包括统计,优化,整合,线性代数模块,傅里叶变换,信号和图像处理,常微分方程求解器等等.这次还没用到,看介绍很强大,是numpy的升级版。
matplotlib是Python的一种开源的扩展可以绘制各种各种的图表。
曲线拟合的例子
import matplotlib.pyplot as plt import math import numpy as np import random import csv plt.rcParams['font.sans-serif'] = ['SimHei']#设置显示中文 fig = plt.figure() ax = fig.add_subplot(111)#将画布分割成1行1列,图像画在从左到右从上到下的第1块 #阶数为6阶 order=6 #生成曲线上的各个点 dataMat = np.loadtxt(open("c:\\yandu.csv","rb"),delimiter=",",skiprows=0) size=dataMat.shape num=size[0] trandata=np.transpose(dataMat)#矩阵转置 xa=trandata[0]#得到天数数组(横坐标) ya=trandata[1]#实测盐度值数组 #数据筛选,去除盐度值为零的,提高拟合精度 i=0 x=[] y=[] for yy in ya: if yy>0: xx=xa[i] i+=1 x.append(xx) y.append(yy) #绘制原始数据 ax.plot(x,y,label=u'原始数据',color='m',linestyle='',marker='.') #计算多项式 c=np.polyfit(x,y,order)#拟合多项式的系数存储在数组c中 yy=np.polyval(c,x)#根据多项式求函数值 #进行曲线绘制 x_new=np.linspace(0, 365, 2000) f_liner=np.polyval(c,x_new) #ax.plot(x,y,color='m',linestyle='',marker='.') ax.plot(x_new,f_liner,label=u'拟合多项式曲线',color='g',linestyle='-',marker='') # labels标签设置 ax.set_xlim(0, 366) ax.set_xlabel(u'天') ax.set_ylabel(u'盐度') ax.set_title(u'盐度的日变化', bbox={'facecolor':'0.8', 'pad':5}) ax.legend() plt.show()
运行结果:
PS:这里再为大家推荐两款相似的在线工具供大家参考:
在线多项式曲线及曲线函数拟合工具:
http://tools.jb51.net/jisuanqi/create_fun
在线绘制多项式/函数曲线图形工具:
http://tools.jb51.net/jisuanqi/fun_draw
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
问题内容: 对于使用6阶多项式插值非线性数据,我有一个非常具体的要求。我看过numpy / scipy例程(scipy.interpolate.InterpolatedUnivariateSpline),这些例程最多只能进行5级插值。 即使没有直接函数可以执行此操作,是否有办法在Python中复制Excel的LINEST线性回归算法?LINEST允许进行6度曲线拟合,但是我不希望将Excel用于任
问题内容: 我有一组近似于2D曲线的点。我想将Python与numpy和scipy配合使用,以找到近似适合这些点的三次贝塞尔曲线路径,在该路径中,我指定两个端点的确切坐标,并返回其他两个控制点的坐标。 我最初以为可以做我想做的事,但是似乎迫使曲线穿过每个数据点(因为我想您希望进行插值)。我以为我走错了路。 我的问题与此相似:如何将贝塞尔曲线拟合到一组数据?,除了他们说他们不想使用numpy。我的偏
本文向大家介绍Python使用matplotlib绘制三维参数曲线操作示例,包括了Python使用matplotlib绘制三维参数曲线操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python使用matplotlib绘制三维参数曲线操作。分享给大家供大家参考,具体如下: 一 代码 二 运行结果 更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数学运算技巧总结
本文向大家介绍Python基于列表list实现的CRUD操作功能示例,包括了Python基于列表list实现的CRUD操作功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python基于列表list实现的CRUD操作功能。分享给大家供大家参考,具体如下: 本篇文章看之前你的先了解python 基础的知识点,比如控制流,变量,数据类型,list,元组,字典 基本操作,该文章主要的目的
本文向大家介绍Python实现曲线点抽稀算法的示例,包括了Python实现曲线点抽稀算法的示例的使用技巧和注意事项,需要的朋友参考一下 本文介绍了Python实现曲线点抽稀算法的示例,分享给大家,具体如下: 目录 何为抽稀 道格拉斯-普克(Douglas-Peuker)算法 垂距限值法 最后 正文 何为抽稀 在处理矢量化数据时,记录中往往会有很多重复数据,对进一步数据处理带来诸多不便。多余的数据一
本文向大家介绍Python使用matplotlib和pandas实现的画图操作【经典示例】,包括了Python使用matplotlib和pandas实现的画图操作【经典示例】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python使用matplotlib和pandas实现的画图操作。分享给大家供大家参考,具体如下: 画图在工作再所难免,尤其在做数据探索时候,下面总结了一些关于pytho