使用stat_compare_means检验多个组是否与零有显着差异?
Use stat_compare_means to test whether multiple groups are significantly different from zero?
我在 ggplot2 中使用 ggpubr::stat_compare_means
来显示多个箱线图的重要性。我试图找到一种方法来显示我的每个箱线图是否与某个值(0)有显着差异,但我只能找到方法来比较它们是否与特定组或所有组的平均值不同。
这是我的情节:
有些组在0以上,有些在0以下。我想测试的是每个组是否与0有显着差异。
目前 stat_compare_means 正在根据此参数计算显着性:
stat_compare_means(label = "p.signif", method = "t.test", ref.group = ".all.", label.y=1.1)
我知道我需要更改 "ref.group" 参数。在这种情况下,我认为它是取所有组的平均值,并测试每个组是否与其有显着差异。
ref.group 的文档说:
"指定参照组的字符串。如果指定,对于给定的分组变量,每个组级别将与参照组(即对照组)进行比较。
ref.group 也可以是“.all.”。在这种情况下,每个分组变量级别都与所有级别(即 basemean)进行比较。"
因为这需要一个字符串,所以我能想到的将我的组与 0 进行比较的唯一方法是制作一个 0 的虚拟控制组,这将是参考组。然后我可以在 ref.group 参数中指向那个组。
有没有其他方法可以将这些组与 0 进行比较?谢谢。
df%>%ggplot(aes(x=species,y=weighted_change))+
geom_hline(yintercept=0,linetype="dashed")+
geom_boxplot(color="orangered")+
labs(x="Species",y="Mean Change",title="Central Basin and Range")+
theme(plot.title = element_text(hjust = 0.5,size = 12, face = "bold"))+
theme(axis.title = element_text(size = 10, face = "bold"))+
theme(axis.text=element_text(size=10,face="bold"))+
theme(axis.text.x = element_text(angle = 45, hjust = 1))+
coord_cartesian(ylim=c(-1.1,1.1))+
stat_compare_means(label = "p.signif", method = "t.test", ref.group = ".all.", label.y=1.1)
我认为 stat_compare_means
在这里实际上不会对你有多大帮助,因为它似乎主要是为比较 组之间而设计的,而你想做一个每组内计算。相反,您可以在转到 ggplot 之前自己计算测试:
library(tidyverse)
# Test whether each group differs from 0
t_tests = iris %>%
group_by(Species) %>%
summarise(P = t.test(Petal.Width, mu = 0)$p.value,
Sig = ifelse(P < 0.05, "*", "ns"),
MaxWidth = max(Petal.Width))
ggplot(iris, aes(x = Species, y = Petal.Width)) +
geom_boxplot() +
# Use the prepared table of test results as data for the geom
geom_text(aes(label = Sig, y = MaxWidth + 0.2), size = 6,
data = t_tests)
因为我没有你的数据,所以我使用了 iris
,但由于 iris 也有一个 species
列,所以应该很清楚发生了什么。
我在 ggplot2 中使用 ggpubr::stat_compare_means
来显示多个箱线图的重要性。我试图找到一种方法来显示我的每个箱线图是否与某个值(0)有显着差异,但我只能找到方法来比较它们是否与特定组或所有组的平均值不同。
这是我的情节:
有些组在0以上,有些在0以下。我想测试的是每个组是否与0有显着差异。
目前 stat_compare_means 正在根据此参数计算显着性:
stat_compare_means(label = "p.signif", method = "t.test", ref.group = ".all.", label.y=1.1)
我知道我需要更改 "ref.group" 参数。在这种情况下,我认为它是取所有组的平均值,并测试每个组是否与其有显着差异。
ref.group 的文档说:
"指定参照组的字符串。如果指定,对于给定的分组变量,每个组级别将与参照组(即对照组)进行比较。 ref.group 也可以是“.all.”。在这种情况下,每个分组变量级别都与所有级别(即 basemean)进行比较。"
因为这需要一个字符串,所以我能想到的将我的组与 0 进行比较的唯一方法是制作一个 0 的虚拟控制组,这将是参考组。然后我可以在 ref.group 参数中指向那个组。
有没有其他方法可以将这些组与 0 进行比较?谢谢。
df%>%ggplot(aes(x=species,y=weighted_change))+
geom_hline(yintercept=0,linetype="dashed")+
geom_boxplot(color="orangered")+
labs(x="Species",y="Mean Change",title="Central Basin and Range")+
theme(plot.title = element_text(hjust = 0.5,size = 12, face = "bold"))+
theme(axis.title = element_text(size = 10, face = "bold"))+
theme(axis.text=element_text(size=10,face="bold"))+
theme(axis.text.x = element_text(angle = 45, hjust = 1))+
coord_cartesian(ylim=c(-1.1,1.1))+
stat_compare_means(label = "p.signif", method = "t.test", ref.group = ".all.", label.y=1.1)
我认为 stat_compare_means
在这里实际上不会对你有多大帮助,因为它似乎主要是为比较 组之间而设计的,而你想做一个每组内计算。相反,您可以在转到 ggplot 之前自己计算测试:
library(tidyverse)
# Test whether each group differs from 0
t_tests = iris %>%
group_by(Species) %>%
summarise(P = t.test(Petal.Width, mu = 0)$p.value,
Sig = ifelse(P < 0.05, "*", "ns"),
MaxWidth = max(Petal.Width))
ggplot(iris, aes(x = Species, y = Petal.Width)) +
geom_boxplot() +
# Use the prepared table of test results as data for the geom
geom_text(aes(label = Sig, y = MaxWidth + 0.2), size = 6,
data = t_tests)
因为我没有你的数据,所以我使用了 iris
,但由于 iris 也有一个 species
列,所以应该很清楚发生了什么。