首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用rstatix包将多个p值添加到ggplot

使用rstatix包将多个p值添加到ggplot
EN

Stack Overflow用户
提问于 2021-10-21 14:15:53
回答 1查看 91关注 0票数 0

我正在尝试将多个p值添加到我的堆叠条形图。我可以使用以下代码将单个p值添加到我的数据中:

代码语言:javascript
复制
library(tidyverse)
library(ggprism)
library(rstatix)

RDT_Pos_genus_pval <- table(RDT_genus_ratio$Ag_RDT, RDT_genus_ratio$Genus_Cytb) %>%  ##filtered to one group for example purposes
                     fisher.test() %>%
                     .$p.value %>%
                      signif(3)
Pos_genus_pval <- data.frame(
  group1 = "Mastomys",
  group2 = "Praomys",
  label = RDT_Pos_genus_pval,
  y.position = 1.05)

RDT_genus_ratio_bar <- ggplot(RDT_genus_ratio) +
  geom_bar(mapping = aes(x = Genus_Cytb, fill = Ag_RDT), position = "fill") +
  labs(y = "Percentage", x = "Genus") +
  scale_y_continuous(labels = scales::percent, guide = "prism_offset_minor") +
  scale_x_discrete() +
  scale_fill_discrete(name = "Antigen Status", labels = c("FALSE" = "Ag -", "TRUE" = "Ag +")) +
  theme_classic() +
  theme(aspect.ratio = 2/1.5, plot.title = element_text(hjust = 0.5, size = 16),
        axis.text.y = element_text(size = 12, vjust = -0.2), axis.text.x = element_text(size = 10),
        axis.title = element_text(size = 12), axis.title.x.bottom = element_text(size = 12, vjust = 0.5)) +
  add_pvalue(Pos_genus_pval, label = "p = {label}")

然而,我想将成对的fisher测试添加到这三个组中。我知道使用rstatix包应该能够做到这一点,方法是专门为此创建一个数据帧,然后在add_pvalue行中添加它来代替Pos_genus_pval。然而,我一直被add_y_position part卡住了(见下文)

代码语言:javascript
复制
asdf <- table(RDT_genus_ratio$Ag_RDT, RDT_genus_ratio$Genus_Cytb) %>%
  pairwise_fisher_test() 

# A tibble: 3 x 6
  group1   group2      n        p    p.adj p.adj.signif
* <chr>    <chr>   <int>    <dbl>    <dbl> <chr>       
1 Mastomys Praomys   316 4.14e- 1 4.14e- 1 ns          
2 Mastomys Rattus    491 7.44e-18 2.23e-17 ****        
3 Praomys  Rattus    209 1.29e- 2 2.58e- 2 *  

asdf <- table(RDT_genus_ratio$Ag_RDT, RDT_genus_ratio$Genus_Cytb) %>%
  pairwise_fisher_test() %>%
  add_y_position(formula = group1 ~ group2) ##this line is where I'm getting stuck 

Error in add_y_position(., formula = group1 ~ group2) : 
  data and formula arguments should be specified.       

我一直在尝试遵循rstatix readmeggprism tutorial中链接的示例,但是我仍然被卡住了。如果您有任何见解,我将不胜感激!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-24 22:45:01

请改用ggpubr中的stat_pvalue_manual。计算pariwise fisher检验,然后添加每个比较的y位置。然后,您可以将生成的表中的任何内容添加到您的图表中。

代码语言:javascript
复制
RDT_Pos_by_genus_fisherstest <- table(RDT_genus_ratio$Ag_RDT, RDT_genus_ratio$Genus_Cytb) %>%
  pairwise_fisher_test() %>%
  mutate(y.position = c(1.03, 1.1, 1.03))
RDT_Pos_by_genus_fisherstest
# A tibble: 3 x 7
  group1   group2      n        p    p.adj p.adj.signif y.position
* <chr>    <chr>   <int>    <dbl>    <dbl> <chr>             <dbl>
1 Mastomys Praomys   316 4.14e- 1 4.14e- 1 ns                 1.03
2 Mastomys Rattus    491 7.44e-18 2.23e-17 ****               1.1
3 Praomys  Rattus    209 1.29e- 2 2.58e- 2 *                  1.03

RDT_genus_ratio_bar <- ggplot(RDT_genus_ratio) +
  geom_bar(mapping = aes(x = Genus_Cytb, fill = Ag_RDT), position = "fill") +
  labs(y = "Percentage", x = "Genus") +
  scale_y_continuous(labels = scales::percent, limits = c(0,1.2,0.1), guide = "prism_offset_minor") +
  scale_x_discrete() +
  scale_fill_discrete(name = "Antigen Status", labels = c("FALSE" = "Ag -", "TRUE" = "Ag +")) +
  theme_classic() +
  theme(aspect.ratio = 2/1.5, plot.title = element_text(hjust = 0.5, size = 16),
        axis.text.y = element_text(size = 12, vjust = -0.2), axis.text.x = element_text(size = 10),
        axis.title = element_text(size = 12), axis.title.x.bottom = element_text(size = 12, vjust = 0.5)) +
  stat_pvalue_manual(RDT_Pos_by_genus_fisherstest,label = "p.adj.signif", size = 3.7, tip.length = 0.25, bracket.shorten = 0.08)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69663615

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档