目录
[核密度估计(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. 基础小提琴图
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()
