R语言如何绘制云雨图(20)

2024-01-15 05:30
文章标签 语言 绘制 20 云雨

本文主要是介绍R语言如何绘制云雨图(20),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.什么是云雨图?

云雨图,顾名思义,由2部分组成,上方的半个小提琴图形似云朵,下方的点图形似雨滴。

上方的半个小提琴图,类似于核密度曲线,其曲线下的面积是1。

下方的点图,其实是频率分布直方图的点状抽象。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-US47KaD4-1652085922727)(https://gitee.com/suozhuoPic/pic/raw/master/images/export-plot%20(12)].png)

2.绘图前的数据准备

​ demo数据可以在https://www.bioladder.cn/shiny/zyp/bioladder2/demoData/rainCloud/demo.txt下载。

​ 包含2个维度的数据,通常每一列是个样本,每一行是个基因

image-20211203171052881

3. R语言怎么画云雨图

# 加载R包,没有安装请先安装  install.packages("包名") 
library(ggplot2)
library(reshape2)
library(RColorBrewer)
library(grid)# 读取云雨图数据文件
df = read.delim("https://www.bioladder.cn/shiny/zyp/bioladder2/demoData/rainCloud/demo.txt",# 这里读取了网络上的demo数据,将此处换成你自己电脑里的文件header = T       # 指定第一行是列名
)
# 把数据转换成ggplot常用的类型(长数据)
df = melt(df)                    # melt出自reshape2包
head(df)                         # 查看转换完成的数据的前几行
# 绘图
ggplot(df,aes(x=variable,   y=value,fill=variable,     # fill填充颜色,根据变量名赋值colour=variable))+ # colour图形边界颜色,根据变量名赋值geom_flat_violin(position = position_nudge(x=.1))+ # 见下段代码geom_dotplot(binaxis = "y",binwidth = 0.1,   # 雨滴间隙stackdir = "down",dotsize = 0.6)+   # 雨滴大小coord_flip()+                  # 翻转坐标轴theme_classic()                # ggplot2主题

geom_flat_violin函数代码

#<<<<<<<<<<<<<<<<<<<<<<<<
# 由于ggplot2并没有提供半小提琴图,所以经由geom_violin的源码修改成geom_flat_violin函数
"%||%" <- function(a, b) {if (!is.null(a)) a else b
}color<-brewer.pal(7,"Set2")[c(1,2,4,5)]geom_flat_violin <- function(mapping = NULL, data = NULL, stat = "ydensity",position = "dodge", trim = TRUE, scale = "area",show.legend = NA, inherit.aes = TRUE, ...) {layer(data = data,mapping = mapping,stat = stat,geom = GeomFlatViolin,position = position,show.legend = show.legend,inherit.aes = inherit.aes,params = list(trim = trim,scale = scale,...))
}GeomFlatViolin <-ggproto("GeomFlatViolin", Geom,setup_data = function(data, params) {data$width <- data$width %||%params$width %||% (resolution(data$x, FALSE) * 0.9)data %>%group_by(group) %>%mutate(ymin = min(y),ymax = max(y),xmin = x,xmax = x + width / 2)},draw_group = function(data, panel_scales, coord) {data <- transform(data, xminv = x,xmaxv = x + violinwidth * (xmax - x)) newdata <- rbind(plyr::arrange(transform(data, x = xmaxv), -y),plyr::arrange(transform(data, x = xminv), y))newdata_Polygon <- rbind(newdata, newdata[1,])newdata_Polygon$colour<-NAnewdata_Path <- plyr::arrange(transform(data, x = xmaxv), -y)ggplot2:::ggname("geom_flat_violin", grobTree(GeomPolygon$draw_panel(newdata_Polygon, panel_scales, coord),GeomPath$draw_panel(newdata_Path, panel_scales, coord)))},draw_key = draw_key_polygon,default_aes = aes(weight = 1, colour = "grey20", fill = "white", size = 0.5,alpha = NA, linetype = "solid"),required_aes = c("x", "y"))findParams <- function(mu, sigma, skew, kurt) {value <- .C("JohnsonMomentFitR", as.double(mu), as.double(sigma),as.double(skew), as.double(kurt - 3), gamma = double(1),delta = double(1), xi = double(1), lambda = double(1),type = integer(1), PACKAGE = "SuppDists")list(gamma = value$gamma, delta = value$delta,xi = value$xi, lambda = value$lambda,type = c("SN", "SL", "SU", "SB")[value$type])
}
#>>>>>>>>>>>>>>>>>>>>>>>>

4. BioLadder生信云平台在线绘制云雨图

不想写代码?可以用BioLadder生信云平台在线绘制云雨图。

网址:https://www.bioladder.cn/web/#/chart/47

image-20220121151014975

这篇关于R语言如何绘制云雨图(20)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607794

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.