python可视化-密度图

server/2024/10/21 7:39:44/

 1、加载数据

import pandas as pd
import numpy as np
from sklearn.datasets import load_iris
import warnings# 禁用所有警告信息
warnings.filterwarnings('ignore')# 加载数据
iris = load_iris()
iris

 iris.keys()

python">df = pd.DataFrame(iris.data, columns=iris.feature_names)
df['target'] = iris.target
df.head()

2、基于matplotlib的密度图

from scipy.stats import gaussian_kde# 根据数据集构造密度函数
density = gaussian_kde(df['sepal width (cm)'])
density.covariance_factor = lambda : .25
density._compute_covariance()# 构造向量作为x轴刻度
xs = np.linspace(1.5, 5, 200)# 初始化
plt.figure(figsize=(8, 6))plt.plot(xs, density(xs))
plt.show()

3、基于seaborn的密度图

import seaborn as sns
import matplotlib.pyplot as pltsns.set(font='SimHei', font_scale=0.8, style="darkgrid") # 解决Seaborn中文显示问题# 构造子图
fig, ax = plt.subplots(2,2,constrained_layout=True, figsize=(12, 8))# 密度图
ax_sub = sns.kdeplot(df['sepal width (cm)'], ax=ax[0][0])
ax_sub.set_title('密度图')# 水平密度图
ax_sub = sns.kdeplot(y=df['sepal width (cm)'], color="skyblue", ax=ax[0][1])
ax_sub.set_title('水平密度图')# 增加阴影
ax_sub = sns.kdeplot(df['sepal width (cm)'], fill=True, ax=ax[1][0])
ax_sub.set_title('增加阴影')sns.kdeplot(data=df, x='sepal width (cm)', fill=True, bw_method=0.1, ax=ax[1][1]).set_title('降低带宽')plt.show()

4、一图绘制多个变量

ax_sunb = sns.kdeplot(data=df, x='sepal width (cm)', fill=True, color='r', label='sepal width (cm)')
ax_sub = sns.kdeplot(df['sepal length (cm)'], fill=True, color="b", label='sepal length (cm)')
plt.legend()
# 修改x标签
plt.xlabel('speal width/speal length')plt.show()

# alpha:修改透明度
sns.kdeplot(data=df, x='sepal width (cm)', hue="target", fill=True, common_norm=False, alpha=0.4)

# 绘制网格(共用坐标轴)
g = sns.FacetGrid(data=df, col='target', hue='target', col_wrap=3)
# 绘制密度图
g = g.map(sns.kdeplot,"sepal width (cm)", cut=0, fill=True, common_norm=False, alpha=1, legend=False)
# 每个网格的标题
g = g.set_titles("{col_name}")plt.show()

# 绘制堆积图
sns.kdeplot(data=df, x='sepal width (cm)', hue='target', common_norm=False, multiple="fill", alpha=1)plt.show()

 


http://www.ppmy.cn/server/106991.html

相关文章

前端手写源码系列(一)—— 手写防抖和节流

目录 1.实现防抖函数(debounce)2.实现节流函数(throttle)时间戳的方式:定时器方式: 3.总结 1.实现防抖函数(debounce) 防抖函数原理:把触发非常频繁的事件合并成一次去执…

深入解析ASP.NET Core 中间件:如何构建高效的请求处理管道

使用ASP.NET Core 中间件实现请求处理管道 前言 ASP.NET Core 是一个跨平台的高性能框架,主要用于构建现代的基于云的、互联网连接的应用程序。在ASP.NET Core 中,Middleware(中间件)是一个核心概念。中间件是处理HTTP请求和响应…

Python实现贪心算法

目录 贪心算法简介贪心算法的基本思想贪心算法的应用场景活动选择问题 Python实现活动选择问题代码解释活动选择问题的解贪心算法的正确性分析贪心算法的其他应用贪心算法的局限性贪心算法的优化与变种总结 贪心算法简介 贪心算法(Greedy Algorithm)是一…

LabVIEW中CANopen Read SDO.vi 和 CANopen Read Write CAN Frame.vi区别

CANopen Read SDO.vi 和 CANopen Read Write CAN Frame.vi 都是 NI-Industrial Communications for CANopen 库中的示例 VI,用于与 CANopen 网络进行通信,但它们的功能和使用场景有所不同。以下是它们的主要区别: 1. 功能层次 CANopen Read W…

Linux:Socket网络编程

目录 1. 理解源 IP 地址和目的 IP 地址 2:认识端口号 3:端口号范围划分 4:理解源端口号和目的端口号 5:理解Socket(套接字) 6:两个传输协议 (TCP/UDP) 6.1:User Datagram Prot…

Linux——文件系统层次结构,绝对路径

一、文件系统层次结构 linux中所有文件存储在文件系统中,文件系统层次结构可以类比为一颗到立的树,最顶层为根目录/,根目录/底又分了/etc,/bin,/boot,/dev等子目录,而这些子目录底下又可以生成子目录分支。 以下为linux中较为重要…

【鸿蒙样式初探】多个组件如何共用同一样式

最近开发鸿蒙,刚接触难免二和尚摸不着头脑,尤其是样式...... 背景 在做银行卡显示的一个小需求时: 每个Text都需要设置fontColor:#FFFFFF" 想着是否可以简单点 解决历程 思路一:(拒绝) 使用Styles 提取封装公…

Python(R)均方根误差平均绝对误差导图

🎯要点 回归模型评估指标评估薪水预测模型评估员工倦怠率模型评估大气分析生成式对抗模型目标对象缺失下,性能估算法追踪模型误差指标降尺度大气学模拟模型准确性评估蛋白染色质相互作用模型评估 Python回归误差指标 平均绝对误差表示数据集中实际值和…