「日拱一码」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()
相关推荐
叁两1 天前
用opencode打造全自动公众号写作流水线,AI 代笔太香了!
前端·人工智能·agent
前端付豪1 天前
LangChain记忆:通过Memory记住上次的对话细节
人工智能·python·langchain
strayCat232551 天前
Clawdbot 源码解读 7: 扩展机制
人工智能·开源
王鑫星1 天前
SWE-bench 首次突破 80%:Claude Opus 4.5 发布,Anthropic 的野心不止于写代码
人工智能
lnix1 天前
当“大龙虾”养在本地:我们离“反SaaS”的AI未来还有多远?
人工智能·aigc
泉城老铁1 天前
Dify知识库如何实现多关键词AND检索?
人工智能
阿星AI工作室1 天前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式
Halo咯咯1 天前
别再学写代码了,顶级工程师现在在学管理AI agent | 值得一读
人工智能
明明如月学长1 天前
被 Claude Code 劝退?这款免费开源好用的 AI 神器更适合普通人
人工智能