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中的函数用法入门教程
Sep 02 Python
Python Requests 基础入门
Apr 07 Python
Python图形绘制操作之正弦曲线实现方法分析
Dec 25 Python
Python实现多条件筛选目标数据功能【测试可用】
Jun 13 Python
简单了解python反射机制的一些知识
Jul 13 Python
Python类中的魔法方法之 __slots__原理解析
Aug 26 Python
python的命名规则知识点总结
Oct 04 Python
python 基于dlib库的人脸检测的实现
Nov 08 Python
python实现提取str字符串/json中多级目录下的某个值
Feb 27 Python
使用jupyter notebook将文件保存为Markdown,HTML等文件格式
Apr 14 Python
python计算auc的方法
Sep 09 Python
python中如何对多变量连续赋值
Jun 03 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
destoon之一键登录设置
2014/06/21 PHP
Centos7安装swoole扩展操作示例
2020/03/26 PHP
javascript计时器详解
2015/02/28 Javascript
JS运动框架之分享侧边栏动画实例
2015/03/03 Javascript
jQuery实现选项卡切换效果简单演示
2015/12/09 Javascript
js实现鼠标拖拽多选功能示例
2017/08/01 Javascript
轻松玩转BootstrapTable(后端使用SpringMVC+Hibernate)
2017/09/06 Javascript
浅谈Vue2.0父子组件间事件派发机制
2018/01/08 Javascript
ajax请求+vue.js渲染+页面加载的示例
2018/02/11 Javascript
取消Bootstrap的dropdown-menu点击默认关闭事件方法
2018/08/10 Javascript
node.js使用redis储存session的方法
2018/09/26 Javascript
ES6知识点整理之数组解构和字符串解构的应用示例
2019/04/17 Javascript
vue数据响应式原理知识点总结
2020/02/16 Javascript
[00:52]玛尔斯技能全介绍
2019/03/06 DOTA
举例讲解Python的Tornado框架实现数据可视化的教程
2015/05/02 Python
Python实现优先级队列结构的方法详解
2016/06/02 Python
windows上安装Anaconda和python的教程详解
2017/03/28 Python
python分布式环境下的限流器的示例
2017/10/26 Python
Python爬取当当、京东、亚马逊图书信息代码实例
2017/12/09 Python
flask中使用蓝图将路由分开写在不同文件实例解析
2018/01/19 Python
浅谈flask中的before_request与after_request
2018/01/20 Python
python实现搜索文本文件内容脚本
2018/06/22 Python
python实现多人聊天室
2020/03/31 Python
Python中psutil的介绍与用法
2019/05/02 Python
Tensorflow不支持AVX2指令集的解决方法
2020/02/03 Python
Python collections模块的使用方法
2020/10/09 Python
HTML5中的autofocus(自动聚焦)属性介绍
2014/04/23 HTML / CSS
你懂得怎么写自荐信吗?
2013/12/27 职场文书
运动会入场解说词
2014/02/07 职场文书
2015年宣传思想工作总结
2015/05/22 职场文书
幽灵公主观后感
2015/06/09 职场文书
装修公司管理制度
2015/08/05 职场文书
2015年教师节广播稿
2015/08/19 职场文书
python 中[0]*2与0*2的区别说明
2021/05/10 Python
tensorflow中的数据类型dtype用法说明
2021/05/26 Python
【海涛解说】史上最给力比赛,挑战DOTA极限
2022/04/01 DOTA