python 绘制拟合曲线并加指定点标识的实现


Posted in Python onJuly 10, 2019

python 绘制拟合曲线并加指定点标识

python 绘制拟合曲线并加指定点标识的实现

import os
import numpy as np
from scipy import log
from scipy.optimize import curve_fit
import matplotlib.pyplot as plt
import math
from sklearn.metrics import r2_score
# 字体
plt.rcParams['font.sans-serif']=['SimHei']

# 拟合函数
def func(x, a, b):
#  y = a * log(x) + b
  y = x/(a*x+b)
  return y

# 拟合的坐标点
x0 = [2, 4, 8, 10, 24, 28, 32, 48] 
y0 = [6.66,8.35,10.81,11.55,13.63,13.68,13.69,13.67]

# 拟合,可选择不同的method
result = curve_fit(func, x0, y0,method='trf')
a, b = result[0] 

# 绘制拟合曲线用
x1 = np.arange(2, 48, 0.1) 
#y1 = a * log(x1) + b
y1 = x1/(a*x1+b)

x0 = np.array(x0)
y0 = np.array(y0)
# 计算r2
y2 = x0/(a*x0+b)
#y2 = a * log(x0) + b
r2 = r2_score(y0, y2)  

#plt.figure(figsize=(7.5, 5)) 
# 坐标字体大小
plt.tick_params(labelsize=11) 
 # 原数据散点
plt.scatter(x0,y0,s=30,marker='o')

# 横纵坐标起止
plt.xlim((0, 50))
plt.ylim((0, round(max(y0))+2))

# 拟合曲线
plt.plot(x1, y1, "blue") 
plt.title("标题",fontsize=13) 
plt.xlabel('X(h)',fontsize=12) 
plt.ylabel('Y(%)',fontsize=12) 

# 指定点,y=9时求x
p = round(9*b/(1-9*a),2)
#p = b/(math.log(9/a))
p = round(p, 2)
# 显示坐标点
plt.scatter(p,9,s=20,marker='x')
# 显示坐标点横线、竖线
plt.vlines(p, 0, 9, colors = "c", linestyles = "dashed")
plt.hlines(9, 0, p, colors = "c", linestyles = "dashed")
# 显示坐标点坐标值
plt.text(p, 9, (float('%.2f'% p),9),ha='left', va='top', fontsize=11)
# 显示公式
m = round(max(y0)/10,1)
print(m)
plt.text(48, m, 'y= x/('+str(round(a,2))+'*x+'+str(round(b,2))+')', ha='right',fontsize=12) 
plt.text(48, m, r'$R^2=$'+str(round(r2,3)), ha='right', va='top',fontsize=12) 

# True 显示网格 
# linestyle 设置线显示的类型(一共四种) 
# color 设置网格的颜色 
# linewidth 设置网格的宽度  
plt.grid(True, linestyle = "--", color = "g", linewidth = "0.5")
plt.show()

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

Python 相关文章推荐
Python导出数据到Excel可读取的CSV文件的方法
May 12 Python
50行Python代码实现人脸检测功能
Jan 23 Python
Python根据成绩分析系统浅析
Feb 11 Python
python解压TAR文件至指定文件夹的实例
Jun 10 Python
python程序运行进程、使用时间、剩余时间显示功能的实现代码
Jul 11 Python
在python中利用dict转json按输入顺序输出内容方式
Feb 27 Python
Python实现常见的几种加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)
May 09 Python
Python读写压缩文件的方法
Jul 30 Python
如何在Win10系统使用Python3连接Hive
Oct 15 Python
Pytest测试框架基本使用方法详解
Nov 25 Python
关于Numpy之repeat、tile的用法总结
Jun 02 Python
Python MNIST手写体识别详解与试练
Nov 07 Python
python 寻找离散序列极值点的方法
Jul 10 #Python
Python中面向对象你应该知道的一下知识
Jul 10 #Python
python实现函数极小值
Jul 10 #Python
通过PHP与Python代码对比的语法差异详解
Jul 10 #Python
python 梯度法求解函数极值的实例
Jul 10 #Python
对Python中小整数对象池和大整数对象池的使用详解
Jul 09 #Python
Python 旋转打印各种矩形的方法
Jul 09 #Python
You might like
php检测文件编码的方法示例
2014/04/25 PHP
PHP中mysqli_affected_rows作用行数返回值分析
2014/12/26 PHP
PHP速成大法
2015/01/30 PHP
php实现获取文件mime类型的方法
2015/02/11 PHP
php+Mysqli利用事务处理转账问题实例
2015/02/11 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
通过PHP实现获取访问用户IP
2020/05/09 PHP
jQuery的一些注意
2006/12/06 Javascript
一页面多XMLHttpRequest对象
2007/01/22 Javascript
jQuery学习基础知识小结
2010/11/25 Javascript
javascript for循环从入门到偏门(效率优化+奇特用法)
2012/08/01 Javascript
javascript时间自动刷新实现原理与步骤
2013/01/06 Javascript
zepto中使用swipe.js制作轮播图附swipeUp,swipeDown不起效果问题
2015/08/27 Javascript
javascript自定义滚动条实现代码
2020/04/20 Javascript
基于jQuery实现歌词滚动版音乐播放器的代码
2016/09/17 Javascript
BootStrap的两种模态框方式
2017/05/10 Javascript
React简单介绍
2017/05/24 Javascript
使用 jQuery 实现表单验证功能
2017/07/05 jQuery
浅谈Vuex@2.3.0 中的 state 支持函数申明
2017/11/22 Javascript
javascript、php关键字搜索函数的使用方法
2018/05/29 Javascript
150行Node.js实现的dns代理工具
2019/08/02 Javascript
bootstrap+spring boot实现面包屑导航功能(前端代码)
2019/10/09 Javascript
JavaScript利用键盘码控制div移动
2020/03/19 Javascript
jQuery AJAX应用实例总结
2020/05/19 jQuery
在vue-cli3.0 中使用预处理器 (Sass/Less/Stylus) 配置全局变量操作
2020/08/10 Javascript
[01:07:34]DOTA2-DPC中国联赛定级赛 RNG vs Aster BO3第二场 1月9日
2021/03/11 DOTA
python获取文件版本信息、公司名和产品名的方法
2014/10/05 Python
Python 占位符的使用方法详解
2019/07/10 Python
python dataframe NaN处理方式
2019/12/26 Python
Django Admin 上传文件到七牛云的示例代码
2020/06/20 Python
Python dict的常用方法示例代码
2020/06/23 Python
IE滤镜与CSS3效果(详细整理分享)
2013/01/25 HTML / CSS
经典洗发水广告词
2014/03/13 职场文书
学校会议通知范文
2015/04/15 职场文书
酒店前台岗位职责
2015/04/16 职场文书
婚庆答谢词大全
2015/09/29 职场文书