R实战 | 利用upset展示实验设计分组(ggupset)

简介: R实战 | 利用upset展示实验设计分组(ggupset)

读图

image.png

可以看到,这个实验有3个处理 KO(敲除)、WT(野生型)、Drug(给药)。并且分别观察试验后 8、12、24h的反应。这么多的分组如何进行一个直观的展示呢?作者给了我们一个值得借鉴的思路。利用upset图的交集特性可以直观的反应分组情况,例如第一列即为敲除8h后的反应,最后一列即为不敲除并且给药48h后的反应。


绘制

# 安装并加载包
install.packages("ggupset")
library(ggupset)
library(ggplot2)
library(tidyverse)
# 导入并查看数据
data(df_complex_conditions)
head(df_complex_conditions)
# 数据为4列。是否敲除、是否给药、观测时间、反应
> head(df_complex_conditions)
# A tibble: 6 x 4
  KO    DrugA Timepoint response
  <lgl> <chr>     <dbl>    <dbl>
1 TRUE  Yes           8     84.3
2 TRUE  Yes           8    105. 
3 TRUE  Yes           8     79.1
4 TRUE  Yes           8    140. 
5 TRUE  Yes           8    108. 
6 TRUE  Yes           8     79.5
# 新增一列为分组标签
df <- df_complex_conditions %>%
      mutate(Label = pmap(list(KO, DrugA, Timepoint), function(KO, DrugA, Timepoint){
       c(if(KO) "KO" else "WT", if(DrugA == "Yes") "Drug", paste0(Timepoint, "h"))
      }))
# 绘制
ggplot(df,aes(x=Label, y=response)) +
  geom_boxplot() + #箱线图
  geom_jitter(aes(color=KO), width=0.1) + #散点
  geom_smooth(method = "lm", aes(group = paste0(KO, "-", DrugA))) + #分组拟合曲线
  scale_x_upset(order_by = "degree", #upset图
                sets = c("KO", "WT", "Drug", "8h", "24h", "48h"),
                position="top", name = "") +
  theme_combmatrix(combmatrix.label.text = element_text(size=12), #upset图主题
                   combmatrix.label.extra_spacing = 5)+
  theme_bw()

出图:

image.png


Tips:因为图为ggplot下画的 所以可自行扩展需要的内容。


相关文章
|
缓存 前端开发 JavaScript
React Table 表格组件使用教程 排序、分页、搜索过滤筛选功能实战开发
在日常开发中,特别是内部使用的后台系统时,我们常常会需要用表格来展示数据,同时提供一些操作用于操作表格内的数据。简单的表格直接用原生 HTML table 就好,但如果要在 React 中实现一个功能丰富的表格,其实是非常不容易的。在本站之前的文章《最好的 6 个 React Table 组件详细亲测推荐》 中有提到过 react-table 这个库,如果对这个库不太了解的同学可以先了解一下,这里不再赘述。简而言之,react-table 是一个非常强大的库,它与常见的表格组件不同,它不负责渲染 HTML 和 CSS,而是提供了一系列的 hooks 让我们可以灵活地构建功能强大的表格组件。
1278 0
|
1月前
|
SQL 开发框架 前端开发
在Winform系统开发中,对表格列表中的内容进行分组展示
在Winform系统开发中,对表格列表中的内容进行分组展示
|
2月前
uniapp实战 —— 竖排多级分类展示
uniapp实战 —— 竖排多级分类展示
36 0
|
4月前
|
Java 数据库连接 数据库
JMETERGUI展示介绍
主要介绍JMETER默认工作区
33 0
|
JavaScript 数据可视化 搜索推荐
高德地图开发实战案例:使用Loca数据源展示海量点标注(海量点、自定义分类图标、聚合、信息提示、3D控件)
高德地图开发实战案例:使用Loca数据源展示海量点标注(海量点、自定义分类图标、聚合、信息提示、3D控件)
517 0
|
移动开发 JavaScript 算法
如何实现动态内容条件筛选
这两天看了一下后端给的接口文档,每一个都要求筛选,而且这个筛选还是多条件的,还是不能固定的,要求根据用户的输入然后筛选,我之前的实现大概是这样子,当用户想要筛选的时候就去检索条件,并输入相关的内容进行筛选
|
JSON 前端开发 JavaScript
列表展示怎么做
列表展示怎么做
|
达摩院 语音技术 开发者
样音展示|学习笔记
快速学习样音展示
109 0
样音展示|学习笔记
|
SQL 数据可视化 JavaScript
DataV图表的数据筛选交互需求梳理及实现样例
本文主要对DataV大屏数据表、气泡地图等组件的筛选交互需求进行一个简单的梳理及样例实现,其中包括单字段单选筛选、单字段多选筛选、多字段共同筛选、字段级联及查询按钮的配置。
1833 3