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

相关文章

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

C语言进阶(预处理命令详解)

《C语言进阶(预处理命令详解)》文章讲解了宏定义规范、头文件包含方式及条件编译应用,强调带参宏需加括号避免计算错误,头文件应声明函数原型以便主函数调用,条件编译通过宏定义控制代码编译,适用于测试与模块... 目录1.宏定义1.1不带参宏1.2带参宏2.头文件的包含2.1头文件中的内容2.2工程结构3.条件编