利用python绘制CDF图的示例代码

 更新时间:2023年08月16日 11:41:36   作者:Thomas_Cai  
这篇文章主要为大家详细介绍了如何利用python实现绘制CDF图,文中的示例代码简洁易懂,具有一定的借鉴价值,感兴趣的小伙伴可以学习一下

一、code

import os.path

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt

csv_path = r"XXX.csv"
save_fig_path = os.path.join(os.path.split(csv_path)[0], "metrics_cdf.png")

# 从CSV读取数据
data = pd.read_csv(csv_path)['XXX']

# 计算CDF
data_sorted = np.sort(data)[::-1]
cdf = np.arange(1, len(data_sorted)+1) / len(data_sorted)

# 绘制CDF图
plt.plot(data_sorted, cdf, linewidth=2)  # marker='.',
plt.xlabel('Value')
plt.ylabel('CDF')
plt.xticks(np.arange(0, 1.1, 0.1))
plt.yticks(np.arange(0, 1.1, 0.1))
plt.title('Cumulative Distribution Function (CDF)')
plt.grid(True)
plt.savefig(save_fig_path)
plt.show()

二、plt.plot的marker有什么可选的标识

在matplotlib库中,plt.plot函数的marker参数用于指定在图上绘制数据点的标识符。这些标识符可以帮助你在图中更清晰地标记数据点的位置。以下是一些常用的marker参数及其对应的标识符:

'.': 小点

',': 像素

'o': 圆圈

'v': 倒三角

'^': 正三角

'<': 左箭头

'>': 右箭头

'1': 下箭头

'2': 上箭头

's': 正方形

'p': 五角星

'*': 星号

'h': 六边形1

'H': 六边形2

'|': 垂直线

'_': 水平线

你可以在plt.plot函数中使用这些标识符来改变数据点的外观。例如,如果要在绘制的线上使用圆圈作为数据点的标识,可以这样设置:

plt.plot(x_data, y_data, marker='o')

其中,x_data和y_data分别是你要绘制的数据的X和Y值。根据需要,你可以选择不同的标识符来突出显示数据点。

三、方法补充

当然除了上文方法,小编还为大家整理了其他实现绘制CDF图的方法,希望对大家有所帮助

方法一

import numpy as np
import statsmodels.api as sm
import matplotlib.pyplot as plt

data = []
ecdf = sm.distributions.ECDF(data)
x = np.linspace(min(data), max(data))
y = ecdf(x)

for a, b in zip(x, y):
    print(a, b)

plt.plot(x, y, linewidth='5', label='XX', color="green", linestyle="dashed")

plt.xlabel('XX', fontsize = 15)
plt.ylabel('CDF', fontsize=15)

plt.xlim(0, 1500)
plt.ylim(0, 1)

plt.xticks(fontsize=14)
plt.yticks(fontsize=14)

# plt.legend(loc='lower right', fontsize = 17) % 当有多个CDF曲线,对曲线进行标注

plt.show()

方法二

利用Matplotlib绘制CDF图

import matplotlib.pyplot as plt
import numpy as np
from scipy import stats
data = np.random.normal(size=1000)
plt.plot(sorted(data), stats.norm.cdf(sorted(data)))
plt.show()

到此这篇关于利用python绘制CDF图的示例代码的文章就介绍到这了,更多相关python CDF图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python使用uv整合Pip、Pyenv和Venv的实战指南

    Python使用uv整合Pip、Pyenv和Venv的实战指南

    Python 的包管理一直是个让开发者又爱又恨的话题,从 pip 到 virtualenv,再到 poetry、conda、pdm,工具层出不穷,但似乎总觉得差点意思,最近,Python 圈子杀出了一匹黑马uv,本文给大家介绍了Python使用uv整合Pip、Pyenv和Venv的实战指南,需要的朋友可以参考下
    2026-05-05
  • python字符串基础操作详解

    python字符串基础操作详解

    这篇文章主要为大家详细介绍了python字符串基础操作,,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • Python pymysql模块安装并操作过程解析

    Python pymysql模块安装并操作过程解析

    这篇文章主要介绍了Python pymysql模块安装并操作过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Tensorflow安装问题: Could not find a version that satisfies the requirement tensorflow

    Tensorflow安装问题: Could not find a version that satisfies the

    这篇文章主要介绍了Tensorflow安装问题: Could not find a version that satisfies the requirement tensorflow,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Python 内置方法和属性详解

    Python 内置方法和属性详解

    这篇文章主要为大家介绍了Python 内置方法和属性,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • 如何用python开发Zeroc Ice应用

    如何用python开发Zeroc Ice应用

    这篇文章主要介绍了如何用python开发Zeroc Ice应用,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2021-01-01
  • python实现mp3文件播放的具体实现代码

    python实现mp3文件播放的具体实现代码

    前段时间在搞一个基于python的语音助手,其中需要用到python播放音频的功能,下面这篇文章主要给大家介绍了关于python实现mp3文件播放的具体实现代码,需要的朋友可以参考下
    2023-05-05
  • python计算无向图节点度的实例代码

    python计算无向图节点度的实例代码

    今天小编就为大家分享一篇python计算无向图节点度的实例代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • python基础操作列表推导式

    python基础操作列表推导式

    列表推导式形式较为简洁,是利用其它列表创建新列表的一种方式,它的工作方式类似于for循环,也可以嵌套if条件判断语句,需要的朋友可以参考下
    2023-04-04
  • Python3二分查找库函数bisect(),bisect_left()和bisect_right()的区别

    Python3二分查找库函数bisect(),bisect_left()和bisect_right()的区别

    这篇文章主要介绍了Python3二分查找库函数bisect(),bisect_left()和bisect_right()的区别,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03

最新评论