Python实现曲线拟合操作示例【基于numpy,scipy,matplotlib库】


Posted in Python onJuly 12, 2018

本文实例讲述了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()

运行结果:

Python实现曲线拟合操作示例【基于numpy,scipy,matplotlib库】

Python 相关文章推荐
python使用reportlab画图示例(含中文汉字)
Dec 03 Python
解析Python中的变量、引用、拷贝和作用域的问题
Apr 07 Python
python冒泡排序简单实现方法
Jul 09 Python
Python 提取dict转换为xml/json/table并输出的实现代码
Aug 28 Python
python 按不同维度求和,最值,均值的实例
Jun 28 Python
django 发送邮件和缓存的实现代码
Jul 18 Python
Python 读取WAV音频文件 画频谱的实例
Mar 14 Python
python3.6.8 + pycharm + PyQt5 环境搭建的图文教程
Jun 11 Python
在CentOS7下安装Python3教程解析
Jul 09 Python
django教程如何自学
Jul 31 Python
python IP地址转整数
Nov 20 Python
Python Spyder 调出缩进对齐线的操作
Feb 26 Python
python跳过第一行快速读取文件内容的实例
Jul 12 #Python
python 读取文本文件的行数据,文件.splitlines()的方法
Jul 12 #Python
Python实现的简单读写csv文件操作示例
Jul 12 #Python
用Python分析3天破10亿的《我不是药神》到底神在哪?
Jul 12 #Python
python之文件读取一行一行的方法
Jul 12 #Python
python 读取文件并替换字段的实例
Jul 12 #Python
python logging重复记录日志问题的解决方法
Jul 12 #Python
You might like
聊天室php&mysql(一)
2006/10/09 PHP
深入php self与$this的详解
2013/06/08 PHP
php用户登录之cookie信息安全分析
2016/05/13 PHP
PHP 进度条函数的简单实例
2017/09/19 PHP
Prototype最新版(1.5 rc2)使用指南(1)
2007/01/10 Javascript
jquery ui dialog ie8出现滚动条的解决方法
2010/12/06 Javascript
JS实现距离上次刷新已过多少秒示例
2014/05/23 Javascript
JavaScript中String.prototype用法实例
2015/05/20 Javascript
javascript事件绑定学习要点
2016/03/09 Javascript
Bootstrap源码解读表单(2)
2016/12/22 Javascript
轻松实现jQuery添加删除按钮Click事件
2017/03/13 Javascript
JS给按钮添加跳转功能类似a标签
2017/05/30 Javascript
vue v-model实现自定义样式多选与单选功能
2018/07/05 Javascript
Element Input组件分析小结
2018/10/11 Javascript
python ip正则式
2009/05/07 Python
python实现查找两个字符串中相同字符并输出的方法
2015/07/11 Python
利用python批量给云主机配置安全组的方法教程
2017/06/21 Python
python3+PyQt5+Qt Designer实现扩展对话框
2018/04/20 Python
解决Django的request.POST获取不到内容的问题
2018/05/28 Python
对python3中, print横向输出的方法详解
2019/01/28 Python
对Python中TKinter模块中的Label组件实例详解
2019/06/14 Python
python 基于TCP协议的套接字编程详解
2019/06/29 Python
Python定时任务随机时间执行的实现方法
2019/08/14 Python
TensorFlow设置日志级别的几种方式小结
2020/02/04 Python
详解Python 循环嵌套
2020/07/09 Python
详解CSS3开启硬件加速的使用和坑
2017/08/21 HTML / CSS
Boden美国官网:英伦原创时装品牌
2017/07/03 全球购物
应届毕业生求职信范例分享
2013/12/17 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
三万活动总结
2014/04/28 职场文书
地球一小时宣传标语
2014/06/24 职场文书
2014派出所所长群众路线对照检查材料思想汇报
2014/09/18 职场文书
2015年煤矿工作总结
2015/04/28 职场文书
嘉年华活动新闻稿
2015/07/17 职场文书
centos环境下nginx高可用集群的搭建指南
2022/07/23 Servers
MySQL 原理与优化之Limit 查询优化
2022/08/14 MySQL