「日拱一码」155 小提琴图

目录

什么是小提琴图?

数学原理

[核密度估计(Kernel Density Estimation, KDE)](#核密度估计(Kernel Density Estimation, KDE))

带宽选择的影响

小提琴图的优势

代码示例

[1. 基础小提琴图](#1. 基础小提琴图)

[2. 水平小提琴图](#2. 水平小提琴图)

[3. 分组小提琴图](#3. 分组小提琴图)

[4. 小提琴图与箱型图对比](#4. 小提琴图与箱型图对比)


什么是小提琴图?

小提琴图是箱形图与核密度图的结合,它能够同时显示:

  • 数据的分布形状(通过核密度估计)
  • 统计摘要信息(中位数、四分位数等)

数学原理

核密度估计(Kernel Density Estimation, KDE)

小提琴图的形状基于核密度估计,公式为:

其中:

  • K 是核函数(通常使用高斯核)
  • h 是带宽参数,控制平滑程度
  • n 是样本数量
  • xi 是样本点

带宽选择的影响

  • 小带宽:密度曲线波动大,显示细节但可能过拟合
  • 大带宽:曲线平滑,可能掩盖重要特征

小提琴图的优势

  1. 信息丰富:比箱形图展示更多分布信息
  2. 直观可视化:清晰显示数据的密度分布
  3. 多组比较:便于比较不同组别的数据分布

代码示例

1. 基础小提琴图

python 复制代码
## 1. 基础小提琴图
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
import pandas as pd

np.random.seed(42)
data1 = np.random.normal(0, 1, 200)
data2 = np.random.normal(5, 1.5, 200)
data3 = np.random.normal(10, 0.8, 200)

# 创建DataFrame
df = pd.DataFrame({
    'Value': np.concatenate([data1, data2, data3]),
    'Category': ['Group A'] * 200 + ['Group B'] * 200 + ['Group C'] * 200
})

# 使用matplotlib绘制小提琴图
plt.figure(figsize=(10, 6))
plt.violinplot([data1, data2, data3], showmeans=True, showmedians=True)
plt.xticks([1, 2, 3], ['Group A', 'Group B', 'Group C'])
plt.title('Basic Violin Plot using Matplotlib')
plt.ylabel('Values')
plt.grid(alpha=0.3)
plt.show()


# 使用Seaborn绘制(更美观)
plt.figure(figsize=(10, 6))
sns.violinplot(data=df, x='Category', y='Value',
               palette='Set2', inner='quartile')
plt.title('Violin Plot using Seaborn')
plt.show()

2. 水平小提琴图

python 复制代码
## 水平小提琴图
plt.figure(figsize=(8, 6))
sns.violinplot(data=df, y='Category', x='Value',
               palette='pastel', inner='box')
plt.title('Horizontal Violin Plot')
plt.show()

3. 分组小提琴图

python 复制代码
## 分组小提琴图
# 创建分组数据
np.random.seed(42)
df_grouped = pd.DataFrame({
    'Value': np.concatenate([
        np.random.normal(0, 1, 100),
        np.random.normal(1, 1, 100),
        np.random.normal(0, 1.5, 100),
        np.random.normal(1, 1.5, 100)
    ]),
    'Category': ['A'] * 200 + ['B'] * 200,
    'Subcategory': ['X'] * 100 + ['Y'] * 100 + ['X'] * 100 + ['Y'] * 100
})

# 分组小提琴图
plt.figure(figsize=(12, 6))
sns.violinplot(data=df_grouped, x='Category', y='Value', hue='Subcategory',
               palette='Set2', split=True, inner='quartile')
plt.title('Grouped Violin Plot')
plt.legend(title='Subcategory')
plt.show()

**4.**小提琴图与箱型图对比

python 复制代码
## 小提琴图与箱型图对比
# 对比小提琴图和箱形图
fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15, 6))

# 小提琴图
sns.violinplot(data=df, x='Category', y='Value', ax=ax1)
ax1.set_title('Violin Plot')

# 箱形图
sns.boxplot(data=df, x='Category', y='Value', ax=ax2)
ax2.set_title('Box Plot')

plt.tight_layout()
plt.show()
相关推荐
张拭心17 小时前
Cursor 又偷偷更新,这个功能太实用:Visual Editor for Cursor Browser
前端·人工智能
吴佳浩18 小时前
大模型 MoE,你明白了么?
人工智能·llm
Blossom.11819 小时前
基于Embedding+图神经网络的开源软件供应链漏洞检测:从SBOM到自动修复的完整实践
人工智能·分布式·深度学习·神经网络·copilot·开源软件·embedding
t1987512820 小时前
电力系统经典节点系统潮流计算MATLAB实现
人工智能·算法·matlab
万悉科技20 小时前
比 Profound 更适合中国企业的GEO产品
大数据·人工智能
mqiqe20 小时前
vLLM(vLLM.ai)生产环境部署大模型
人工智能·vllm
V1ncent Chen20 小时前
机器是如何“洞察“世界的?:深度学习
人工智能·深度学习
AI营销前沿20 小时前
中国AI营销专家深度解析:谁在定义AI营销的未来?
人工智能
前端大卫20 小时前
【重磅福利】学生认证可免费领取 Gemini 3 Pro 一年
前端·人工智能
汽车仪器仪表相关领域21 小时前
LambdaCAN:重构专业空燃比测量的数字化范式
大数据·人工智能·功能测试·安全·重构·汽车·压力测试