嗨,我有一个可能是一个非常简单的问题,但我无法弄清楚。我正在使用ddply创建一个在ggplot2中使用的数据帧。
这是我的数据被截断:
Subject Group Day gkg Strain
PE4 E 1 0.829556075 P
PE5 E 1 0.871823204 P
PE6 E 1 1.135461255 P
PS4 S 1 3.316062176 P
PS5 S 1 2.61627907 P
PS6 S 1 3.286004057 P
WE4 E 1 0.154101563 W
WE6 E 1 1.317852495 W
WS4 S 1 2.007434944 W
WS5 S 1 1.28 W
PE4 E 2 0.642209302 P
PE5 E 2 0.502644788 P
PE6 E 2 1.319834559 P
PS4 S 2 3.350515464 P
PS5 S 2 2.994241843 P
PS6 S 2 3.507014028 P
WE4 E 2 0.109366337 W
WE5 E 2 0.493125 W
WE6 E 2 0.721960784 W
WS4 S 2 2.542056075 W
WS5 S 2 1.23752495 W
我根据组E或S
创建了此数据的子集Edata = which(data$Group == "E")
e = data[Edata,]
Sdata = which(data$Group == "S")
s= data[Sdata,]
然后我尝试使用ddply创建一个数据框,包括均值,标准差,均值的标准误差
newdataIntakeEGKG = ddply(e, .(e$Strain, e$Day), summarise,
N = sum(!is.na(e$gkg)),
mean = mean(e$gkg, na.rm = TRUE),
sd = sd(e$gkg, na.rm = TRUE),
se = sd(e$gkg, na.rm = TRUE)/sqrt(sum(!is.na(e$gkg))))
这会生成以下输出:
e$Strain e$Day N mean sd se
1 P 1 60 0.630856 0.3593886 0.04639687
2 P 2 60 0.630856 0.3593886 0.04639687
3 P 3 60 0.630856 0.3593886 0.04639687
4 P 4 60 0.630856 0.3593886 0.04639687
5 W 1 60 0.630856 0.3593886 0.04639687
6 W 2 60 0.630856 0.3593886 0.04639687
7 W 3 60 0.630856 0.3593886 0.04639687
8 W 4 60 0.630856 0.3593886 0.04639687
当我手工计算时,我学会了它取两个菌株的平均值。我哪里出错了?
答案 0 :(得分:1)
您不希望ddply呼叫中的所有e$
。看看是否有效。
ddply(e, .(Strain, Day), summarise,
N=sum(!is.na(gkg)),
mean=mean(gkg, na.rm=TRUE),
sd=sd(gkg, na.rm=TRUE),
se=sd(gkg, na.rm=TRUE)/sqrt(sum(!is.na(gkg))))
稍微更清洁的选择,虽然它可能不一定会给出相同的结果:
ddply(na.omit(e), .(Strain, Day), summarise,
N=length(gkg), mean=mean(gkg), sd=sd(gkg), se=sd(gkg)/length(gkg))