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 leveldb
Jan 18 Python
python 实现对文件夹内的文件排序编号
Apr 12 Python
Python实现读取字符串按列分配后按行输出示例
Apr 17 Python
python如何创建TCP服务端和客户端
Aug 26 Python
python装饰器简介---这一篇也许就够了(推荐)
Apr 01 Python
由Python编写的MySQL管理工具代码实例
Apr 09 Python
python jenkins 打包构建代码的示例代码
Nov 29 Python
python 和c++实现旋转矩阵到欧拉角的变换方式
Dec 04 Python
Pytorch实现的手写数字mnist识别功能完整示例
Dec 13 Python
Python实现RabbitMQ6种消息模型的示例代码
Mar 30 Python
Python程序慢的重要原因
Sep 04 Python
python爬虫中采集中遇到的问题整理
Nov 27 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 session和cookie使用说明
2010/04/07 PHP
PHP 图像尺寸调整代码
2010/05/26 PHP
PHP中strpos、strstr和stripos、stristr函数分析
2016/06/11 PHP
PHP实现bitmap位图排序与求交集的方法
2016/07/28 PHP
JQuery 1.6发布 性能提升,同时包含大量破坏性变更
2011/05/10 Javascript
angularjs实现与服务器交互分享
2014/06/24 Javascript
js随机生成字母数字组合的字符串 随机动画数字
2015/09/02 Javascript
喜大普奔!jQuery发布 3.0 最终版
2016/06/12 Javascript
js正则表达式注册页面表单验证
2016/10/11 Javascript
jQuery实现复选框的全选和反选
2017/02/02 Javascript
javascript实现table单元格点击展开隐藏效果(实例代码)
2017/04/10 Javascript
Vue实现带进度条的文件拖动上传功能
2018/02/23 Javascript
关于Vue组件库开发详析
2018/07/01 Javascript
Bootstrap-table使用footerFormatter做统计列功能
2018/09/07 Javascript
JS canvas绘制五子棋的棋盘
2020/05/28 Javascript
解决layui追加或者动态修改的表单元素“没效果”的问题
2019/09/18 Javascript
解决ele ui 表格表头太长问题的实现
2019/11/13 Javascript
深入理解 TypeScript Reflect Metadata
2019/12/12 Javascript
JS实现简易计算器
2020/02/14 Javascript
Python列表生成器的循环技巧分享
2015/03/06 Python
python通过imaplib模块读取gmail里邮件的方法
2015/05/08 Python
Python基于回溯法子集树模板解决野人与传教士问题示例
2017/09/11 Python
详解python中list的使用
2019/03/15 Python
Django用户认证系统 组与权限解析
2019/08/02 Python
django ManyToManyField多对多关系的实例详解
2019/08/09 Python
Python读写压缩文件的方法
2020/07/30 Python
Python正则re模块使用步骤及原理解析
2020/08/18 Python
html5 学习简单的拾色器
2010/09/03 HTML / CSS
春节活动策划方案
2014/01/24 职场文书
生产部岗位职责范文
2014/02/07 职场文书
副职竞争上岗演讲稿
2014/05/12 职场文书
私用公车造成事故检讨书
2014/11/16 职场文书
2015元旦主持词开场白和结束语
2014/12/14 职场文书
2015小学教育教学工作总结
2015/07/21 职场文书
高三物理教学反思
2016/02/20 职场文书
PyTorch dropout设置训练和测试模式的实现
2021/05/27 Python