密度图的密度估计_R-ggridges包:山峰叠峦图

f39ad0a1c558649b8592a701081a50fa.png

很忙,很久没有写文章。学习R绘图,这些都是我的兴趣爱好,并非我大的主业。也被我朋友说了很多次,别做这些没用的,既不能带来实际的收益,又耽误正事的时间。

但是我可能对绘图有着某种浓烈的兴趣吧,所以总是抽出时间来瞎捣鼓这些。所以今天跟大家分享一个最近无意中实现的对于R-ggridges包的改进。ggridges包有一个很惊艳的函数geom_density_ridges_gradient()可以绘制多数据系列的核密度估计图,如下图所示:

6948ae88364d935d981efacf7a9040d6.png
#代码如下:
library(ggplot2)
library(ggridges)
#theme_set(theme_ridges())
ggplot(lincoln_weather, aes(x = `Mean Temperature [F]`, y = `Month`)) +
geom_density_ridges_gradient(aes(fill = `Month`), scale = 3, size = 0.3) +  theme(legend.position = "none")

在这个函数中,fill的颜色还可以以x轴的数值作为映射,如下图所示:

4eae13c1aba2f281ba8c901db94d4838.png

#代码如下: library(ggplot2) library(ggridges) #theme_set(theme_ridges()) library(RColorBrewer) Colormap<- colorRampPalette(rev(brewer.pal(11,'Spectral')))(32) ggplot(lincoln_weather, aes(x = `Mean Temperature [F]`, y = `Month`)) + geom_density_ridges_gradient(aes(fill = ..x..), scale = 3, size = 0.3 ) + scale_fill_gradientn(colours=Colormap,name = "Temp. [F]")

但是这种图好看归好看,存在两个问题: 1. 由于没有Y轴数值,无法得知每个数据系列对应的Y轴数值,也就无法得到核密度估计得具体数值,只能看到数据大概的分布形状; 2.这个函数只能绘制这种核密度估计的山峰叠峦图,但是有时候我们只是想展示多数据系列的时序数据的波动,而不是核密度估计。 所以,我自己研究解决了这两个问题:下图就是核密度估计的山峰叠峦图,但是每个数据系列的核密度估计面积的高度对应核密度估计得数值,这就相当于将Y轴的对应数值使用颜色映射实现啦。

92b75e7990e5b5bdd8ff62f1439df92c.png

下面就是使用山峰叠峦图展示多数据系列的时序数据,而不是核密度估计,如下图1所示。但是这个图也存在之前的问题:由于没有Y轴数值,无法得知每个数据系列对应的Y轴数值。图2所示就将Y轴数值映射到颜色colormap,这样就可以得到每个时间点对应的数值。

2ce24c8206728c887a3d54bd65fce437.png
图1

ea1b5481f27113bee5b845ed9975e357.png
图2

大家,肯定想知道这些怎么实现的。所以,我现在想把这几个图的函数打包供大家直接使用。但是由于我时间有限,最近比较忙。顺便看有没有有共同爱好的之士,同时又会打包的朋友。大家可以一起合作,将这几个函数打包package,供大家直接使用。

http://weixin.qq.com/r/BCknP0PElB7rrQdc93wW (二维码自动识别)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值