「日拱一码」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()
相关推荐
HIT_Weston2 小时前
45、【Agent】【OpenCode】本地代理分析(请求&接收回调)
人工智能·agent·opencode
逻辑君3 小时前
认知神经科学研究报告【20260010】
人工智能·深度学习·神经网络·机器学习
星河耀银海3 小时前
远控体验分享:安全与实用性参考
人工智能·安全·微服务
企业架构师老王3 小时前
2026企业架构演进:科普Agent(龙虾)如何从“极客玩具”走向实在Agent规模化落地?
人工智能·ai·架构
GreenTea3 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
鬼先生_sir4 小时前
Spring AI Alibaba 1.1.2.2 完整知识点库
人工智能·ai·agent·源码解析·springai
深念Y4 小时前
豆包AI能力集成方案:基于会话管理的API网关设计
人工智能
龙文浩_4 小时前
Attention Mechanism: From Theory to Code
人工智能·深度学习·神经网络·学习·自然语言处理
ulimate_4 小时前
八卡算力、三个Baseline算法(WALLOSS、pi0、DreamZero)
人工智能
深小乐4 小时前
AI 周刊【2026.04.06-04.12】:Anthropic 藏起最强模型、AI 社会矛盾激化、"欢乐马"登顶
人工智能