logo

Ant Design Charts

  • 教程
  • 选项
  • 图表示例
  • 所有产品antv logo arrow
  • 2.0.0
  • 📈 图表分类
  • 统计图表
    • 图表组成
    • 图表组件 - Component
      • 标题(Title)
      • 坐标轴(Axis)
      • 图例(Legend)
      • 滚动条(Scrollbar)
      • 缩略轴(Slider)
      • 提示信息(Tooltip)
      • 数据标签(Label)
    • 核心概念 - Core
      • 视图(View)
      • 数据(Data)
        • 概览
        • custom
        • ema
        • fetch
        • filter
        • fold
        • inline
        • join
        • kde
        • log
        • map
        • pick
        • rename
        • slice
        • sort
        • sortBy
      • 比例尺(Scale)
        • 概览
        • band
        • linear
        • log
        • ordinal
        • point
        • pow
        • quantile
        • quantize
        • sqrt
        • threshold
        • time
      • 转换(Transform)
        • 概览
        • bin
        • binX
        • diffY
        • dodgeX
        • flexX
        • group
        • groupColor
        • groupX
        • groupY
        • jitter
        • jitterX
        • jitterY
        • normalizeY
        • pack
        • sample
        • select
        • selectX
        • selectY
        • sortColor
        • sortX
        • sortY
        • stackEnter
        • stackY
        • symmetryY
      • 坐标系(Coordinate)
        • 概览
        • fisheye
        • parallel
        • polar
        • radial
        • theta
        • transpose
        • cartesian3D
      • 样式(Style)
      • 动画(Animate)
        • 概览
        • fadeIn
        • fadeOut
        • growInX
        • growInY
        • morphing
        • pathIn
        • scaleInX
        • scaleInY
        • scaleOutX
        • scaleOutY
        • waveIn
        • zoomIn
        • zoomOut
      • 状态(State)
      • 交互(Interaction)
        • 概览
        • brushAxisHighlight
        • brushHighlight
        • brushXHighlight
        • brushYHighlight
        • brushFilter
        • brushXFilter
        • brushYFilter
        • chartIndex
        • elementHighlight
        • elementHighlightByColor
        • elementHighlightByX
        • elementSelect
        • elementSelectByColor
        • elementSelectByX
        • fisheye
        • legendFilter
        • legendHighlight
        • poptip
        • scrollbarFilter
        • sliderFilter
      • 复合(Composition)
        • 概览
        • facetCircle
        • facetRect
        • repeatMatrix
        • spaceFlex
        • spaceLayer
        • timingKeyframe
      • 主题(Theme)
        • 概览
        • academy
        • classic
        • classicDark
      • 事件(Event)
      • 颜色映射(Color)
    • 专有配置 - Specal Plot
      • Area 面积图
      • Bar 条形图
      • CirclePacking 捆绑图
      • DualAxes 双轴图
      • Gauge 仪表盘
      • Line 折线图
      • Rose 玫瑰图
      • Sankey 桑基图
      • Scatter 散点图
      • Sunburst 旭日图
      • Treemap 矩阵树图
      • Venn 韦恩图
      • WordCloud 词云图
      • Column 柱状图
      • Pie 饼图
      • BidirectionalBar 对称条形图
      • Box 箱线图
      • Bullet 子弹图
      • Funnel 漏斗图
      • Heatmap 热力图
      • Histogram 直方图
      • Liquid 水波图
      • Radar 雷达图
      • Stock 股票图
      • Tiny 迷你图
      • Violin 小提琴图
      • Waterfall 瀑布图
      • RadialBar 玉珏图
  • 关系图组件
    • 总览
    • MindMap 思维导图
    • Fishbone 鱼骨图
    • IndentedTree 缩进树图
    • Dendrogram 生态树图
    • OrganizationChart 组织结构图
    • FlowGraph 流程图
    • FlowDirectionGraph 流向图
    • NetworkGraph 网络图
    • FAQ

kde

上一篇
join
下一篇
log

Resources

Ant Design
Galacea Effects
Umi-React 应用开发框架
Dumi-组件/文档研发工具
ahooks-React Hooks 库

社区

体验科技专栏
seeconfSEE Conf-蚂蚁体验科技大会

帮助

GitHub
StackOverflow

more products更多产品

Ant DesignAnt Design-企业级 UI 设计语言
yuque语雀-知识创作与分享工具
EggEgg-企业级 Node 开发框架
kitchenKitchen-Sketch 工具集
GalaceanGalacean-互动图形解决方案
xtech蚂蚁体验科技
© Copyright 2025 Ant Group Co., Ltd..备案号:京ICP备15032932号-38

Loading...

概述

核密度估计(Kernel Density Estimation,简称 KDE)是一种非参数统计方法,用于估计随机变量的概率密度函数。在 Ant Design Charts 中,KDE 数据转换可以对指定的数据进行核密度算法处理,生成概率密度函数(PDF)数据,底层使用开源库 pdfast,该库使用三角形核函数,优化为 O(N + K) 时间复杂度。

在数据处理后,数据会增加两个字段(默认为 y 和 size),均为数组类型,用于表示密度分布的点和对应的密度值。

使用场景

  1. 密度图(Density Plot):展示数据分布的连续估计,比直方图更平滑地展示数据分布。

  2. 小提琴图(Violin Plot):结合箱线图和密度图的特点,既可以展示数据的分布形状,又能显示关键统计信息。

  3. 多组数据分布比较:通过 groupBy 参数,可以同时展示和比较多个分组的数据分布情况。

  4. 平滑的数据可视化:当需要对离散数据点进行平滑处理,展示其整体趋势和分布时。

  5. 不同坐标系下的密度分析:可以在直角坐标系或极坐标系中应用,创建不同视角的数据分布可视化。

配置项

属性描述类型默认值必选
field进行核密度算法的数据字段string-是
groupBy对数据进行分组的分组字段,可以指定多个string[]-是
as进行 KDE 处理之后,存储的字段[string, string]['y', 'size']否
min指定处理范围的最小值number数据最小值否
max指定处理范围的最大值number数据最大值否
size算法最终生成数据的条数,值越大密度曲线越精细number10否
width确定一个元素左右影响多少点,类似于 bandWidth,值越大曲线越平滑number2否

复杂类型说明

  • as:指定 KDE 处理后生成的两个字段名,第一个字段存储 x 值(即数据点的位置),第二个字段存储 y 值(即对应的密度值)。这两个字段都是数组类型,长度由 size 参数决定。

参数调整效果

  • size:该参数决定了生成的密度曲线的精细程度。值越大,生成的点越多,密度曲线越精细。在示例中可以看到从默认的 10 增加到 20 或 30 的效果。

  • width:该参数控制密度曲线的平滑程度,类似于核密度估计中的带宽参数。值越大,曲线越平滑,但可能会丢失一些细节。

示例

基础密度图

下面的示例展示了如何创建基本的密度图,展示不同物种的数据分布:

{
"tooltip": false
}

在这个示例中,我们将 size 参数设置为 20,比默认值 10 更大,从而获得更精细的密度曲线。

极坐标系中的小提琴图

在极坐标系中使用 KDE 可以创建环形的小提琴图,为数据分布可视化提供新的视角:

{
"autoFit": true,
"coordinate": {
"type": "polar"
},
"children": [
{
"type": "density",
"data": {
"transform": [
{
"type": "kde",
"field": "y",
"groupBy": [
"x",
"species"
]
}
]
},
"encode": {
"x": "x",
"y": "y",
"series": "species",
"color": "species",
"size": "size"
},
"tooltip": false
},
{
"type": "boxplot",
"encode": {
"x": "x",
"y": "y",
"series": "species",
"color": "species",
"shape": "violin"
},
"style": {
"opacity": 0.5,
"strokeOpacity": 0.5,
"point": false
}
}
]
}

这个示例展示了如何将 KDE 与箱线图结合使用,创建小提琴图。在极坐标系中,小提琴图呈环形分布,提供了不同的视角来观察数据分布。

自定义参数的密度图

通过调整 KDE 的参数,可以控制密度估计的平滑程度和精度:

{
"tooltip": false
}

这个示例展示了如何自定义 KDE 的各种参数:

  1. size: 30 - 增加采样点数量,获得更精细的密度曲线
  2. width: 3 - 增加带宽,使曲线更平滑
  3. min: 0 和 max: 8 - 指定处理范围的最小值和最大值
  4. as: ['density_x', 'density_y'] - 自定义输出字段名

这些参数的调整可以帮助你获得更精细或更平滑的密度曲线,根据实际需求进行调整。

总结

KDE 数据转换是 Ant Design Charts 中一个强大的工具,可以帮助你创建各种密度相关的可视化,如密度图和小提琴图。通过调整其参数,你可以控制密度曲线的精细度和平滑度,以满足不同的可视化需求。

在不同的坐标系中使用 KDE,可以为数据分布提供不同的视角。结合其他图表类型,如箱线图,可以创建更丰富的数据可视化。

更多的案例,可以查看图表示例 - 小提琴图页面。