Python应用实现双指数函数及拟合代码实例


Posted in Python onJune 19, 2020

双指数函数

待拟合曲线为 y(x) = bepx + ceqx

import matplotlib.pyplot as plt

x = ([0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4, 0.45, 0.5,
   0.55, 0.6, 0.65, 0.7, 0.75, 0.8, 0.85, 0.9, 0.95, 1.0])
y = ([0.33, 0.26, 0.18, 0.16, 0.12, 0.09, 0.08, 0.07, 0.06, 0.06,
   0.06, 0.07, 0.09, 0.1, 0.15, 0.19, 0.25, 0.36, 0.47, 0.68])

plt.scatter(x, y)
plt.show()

Python应用实现双指数函数及拟合代码实例

拟合

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


def double_exp(x, b, c, p, q):
  x = np.array(x)
  return b*np.exp(p*x) + c*np.exp(q*x)


x = ([0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4, 0.45, 0.5,
   0.55, 0.6, 0.65, 0.7, 0.75, 0.8, 0.85, 0.9, 0.95, 1.0])
y = ([0.33, 0.26, 0.18, 0.16, 0.12, 0.09, 0.08, 0.07, 0.06, 0.06,
   0.06, 0.07, 0.09, 0.1, 0.15, 0.19, 0.25, 0.36, 0.47, 0.68])

popt, pcov = curve_fit(double_exp, x, y, [1, 1, 1, 1])
print(popt)

b = popt[0]
c = popt[1]
p = popt[2]
q = popt[3]

y_fit = double_exp(x, b, c, p, q)

plt.scatter(x, y)
plt.plot(x, y_fit, color='red', linewidth=1.0)

plt.show()

Python应用实现双指数函数及拟合代码实例

numpy 库,实现列表转矩阵,得以进行数学运算。matplotlib.pyplot 库,绘制图像。scipy.optimize 库,curve_fit() 函数,使用非线性最小二乘法拟合曲线。curve_fit()popt,拟合结果,在这里指b, c, p, q 的值。povc,该拟合结果对应的协方差。

拟合结果参数原函数拟合结果误差b0.00110.00110c0.42000.42420.42%p6.39986.49881.55%q-5.1551-5.21641.19%

误差可以满意。

经过测试,如果将初始参数设置为原函数参数(保留 4 位小数),拟合得到的结果并未发生变化。

经过测试,拟合使用的三种方法,"trf","lm" 和 "dogbox" 对该函数拟合结果影响微乎其微。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
详解Python中的循环语句的用法
Apr 09 Python
Python编程之event对象的用法实例分析
Mar 23 Python
python用户管理系统
Mar 13 Python
Python入门必须知道的11个知识点
Mar 21 Python
Python3.5 创建文件的简单实例
Apr 26 Python
Python对接支付宝支付自实现功能
Oct 10 Python
python-视频分帧&多帧合成视频实例
Dec 10 Python
完美解决keras保存好的model不能成功加载问题
Jun 11 Python
如何理解python对象
Jun 21 Python
python实现图片,视频人脸识别(dlib版)
Nov 18 Python
详解python字符串驻留技术
May 21 Python
python Django框架快速入门教程(后台管理)
Jul 21 Python
PyQT5 实现快捷键复制表格数据的方法示例
Jun 19 #Python
如何在keras中添加自己的优化器(如adam等)
Jun 19 #Python
详解pyinstaller生成exe的闪退问题解决方案
Jun 19 #Python
Python实现爬取并分析电商评论
Jun 19 #Python
keras 实现轻量级网络ShuffleNet教程
Jun 19 #Python
Python爬虫实现HTTP网络请求多种实现方式
Jun 19 #Python
Keras设置以及获取权重的实现
Jun 19 #Python
You might like
php实现curl模拟ftp上传的方法
2015/07/29 PHP
PHP实现网页内容html标签补全和过滤的方法小结【2种方法】
2017/04/27 PHP
CheckBox 如何实现全选?
2006/06/23 Javascript
JavaScript 变量命名规则
2009/09/23 Javascript
cnblogs TagCloud基于jquery的实现代码
2010/06/11 Javascript
javascript写的日历类(基于pj)
2010/12/28 Javascript
IE6浏览器中window.location.href无效的解决方法
2014/11/20 Javascript
js实现有时间限制消失的图片方法
2015/02/27 Javascript
jquery SweetAlert插件实现响应式提示框
2015/08/18 Javascript
AngularJs expression详解及简单示例
2016/09/01 Javascript
jQuery tagsinput在h5邮件客户端中应用详解
2016/09/26 Javascript
js 点击a标签 获取a的自定义属性方法
2016/11/21 Javascript
js+html5实现复制文字按钮
2017/07/15 Javascript
使用npm安装最新版本nodejs
2018/01/18 NodeJs
小程序封装wx.request请求并创建接口管理文件的实现
2019/04/29 Javascript
Js生成随机数/随机字符串的方法小结【5种方法】
2020/05/27 Javascript
JS中箭头函数与this的写法和理解
2021/01/14 Javascript
[54:25]Ti4 循环赛第三日LGD vs MOUZ
2014/07/12 DOTA
[02:22]《新闻直播间》2017年08月14日
2017/08/15 DOTA
介绍Python中的文档测试模块
2015/04/28 Python
python利用rsa库做公钥解密的方法教程
2017/12/10 Python
Python实现定时精度可调节的定时器
2018/04/15 Python
用python编写第一个IDA插件的实例
2018/05/29 Python
CentOS下Python3的安装及创建虚拟环境的方法
2018/11/28 Python
python 使用pandas计算累积求和的方法
2019/02/08 Python
解决Django中多条件查询的问题
2019/07/18 Python
html5拖曳操作 HTML5实现网页元素的拖放操作
2013/01/02 HTML / CSS
美国在线家装零售商:Build.com
2016/09/02 全球购物
世界上最好的足球商店:Unisport
2019/03/02 全球购物
德国滑雪和户外用品网上商店:XSPO
2019/10/30 全球购物
Bonprix法国:时尚、鞋子、家居
2020/12/29 全球购物
Linux中如何用命令创建目录
2016/12/02 面试题
司机岗位职责
2013/11/15 职场文书
军训心得体会
2013/12/31 职场文书
工程管理专业毕业生自荐信
2014/01/24 职场文书
九一八事变演讲稿范文
2014/09/14 职场文书