时间:2021-05-22
双指数函数
待拟合曲线为 y(x) = bepx + ceqx
import matplotlib.pyplot as pltx = ([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()拟合
import numpy as npimport matplotlib.pyplot as pltfrom scipy.optimize import curve_fitdef 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()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" 对该函数拟合结果影响微乎其微。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Plots是一款图形绘图应用,它可以轻松实现数学公式的可视化。你可以用它来绘制任意三角函数、双曲函数、指数函数和对数函数的和与积。在Linux上使用Plots绘
本文实例讲述了Python实现的拟合二元一次函数功能。分享给大家供大家参考,具体如下:背景:使用scipy拟合一元二次函数。参考:HYRYStudio-《用Py
在办公中经常会用到excel中的指数函数,如果不懂的朋友不妨一起来学习研究一番,下面为大家介绍excel指数函数使用方法,不会的朋友可以参考本文,来看看吧!
在办公中经常会用到excel中的指数函数,如果不懂的朋友不妨一起来学习研究一番,下面小编就为大家介绍excel指数函数使用方法,不会的朋友可以参考本文,来看看吧
本文实例讲述了Python线性拟合实现函数与用法。分享给大家供大家参考,具体如下:1.参考别人写的:#-*-coding:utf-8-*-importmathi