data:image/s3,"s3://crabby-images/51c21/51c2181314b1c4f98f44059d43c88b5af3f1ee44" alt=""
使用するパッケージ(パッケージのインストール)
R
library(ggplot2)
library(ggsignif)
ファイル”ebar”をdatに格納します (ファイルの読み込み)
R
dat <- read.csv("ebar.csv", header = T, fileEncoding = "UTF-8")
R
head(dat)
data:image/s3,"s3://crabby-images/bcc04/bcc042cd953a4eb2b0c2b94259d21f7a3d3adabe" alt=""
列pre_postの配列を確認します
R
#まずはfactor変数に変換します
dat$pre_post <- as.factor(dat$pre_post)
#factor変数にすることでレベルが付与されます
levels(dat$pre_post)
data:image/s3,"s3://crabby-images/8c553/8c5530b47fc42442f7ea16bca8dca0c1fc038f37" alt=""
このままではx軸が後→前の配列になるので入れ替えます
R
dat$pre_post <- relevel(dat$pre_post, ref="前")
#確認してみます
levels(dat$pre_post)
data:image/s3,"s3://crabby-images/45a4d/45a4d7ac00045848861120d8988ecc8f2a91aeac" alt=""
これでx軸の準備は完了
ggplotの基本的な描き方です
R
(g1 <- ggplot2::ggplot(dat, aes(x = pre_post, y = value)))
data:image/s3,"s3://crabby-images/13c6d/13c6d4c056935cbb8842f364d77b6ae5df7e2dff" alt=""
R
(g2 <- g1 + geom_point())
data:image/s3,"s3://crabby-images/b7cfa/b7cfab56cebd71d107b199fff932df1377cbea9a" alt=""
R
(g3 <- g2 + theme_bw())
data:image/s3,"s3://crabby-images/208cb/208cb02f2c9feff1552d206f30e26021fa47e2c9" alt=""
それでは実践編へ
標準誤差をエラーバーとしたグラフを描きます
R
pos1 <- ggplot2::position_jitterdodge(
jitter.width = 0,#横にずらす
jitter.height = 0,#縦にずらす
dodge.width = 0.5#カテゴリで分ける
)
(g4 <- ggplot(data = dat,
aes(
x = pre_post,
y = value,
colour = treat
)
))
data:image/s3,"s3://crabby-images/8fad9/8fad9b6a7a28970467248c9881d2833392748ee4" alt=""
R
(g5 <- g4 +
geom_jitter(alpha = 0.4, position = pos1) + #alpha重なりの濃さ
stat_summary(aes(x = as.numeric(pre_post) + 0.07),
fun = "mean", geom = "point", size = 3, position = pos1)
)
data:image/s3,"s3://crabby-images/b6140/b6140191e99635f40cbb05006eb5e09a29a68094" alt=""
標準誤差(fun.data = “mean_se”)
R
(g6 <- g5 +#平均値のプロット
stat_summary(aes(x = as.numeric(pre_post) + 0.07),
fun.data = "mean_se",
geom = "errorbar",
width = 0.1,#ひげの横幅
lwd = 1,#ひげの棒の幅
position = pos1
))
data:image/s3,"s3://crabby-images/dd9bc/dd9bc0d5af25cb8e94ad77b35ff5b30ed0c0268f" alt=""
95%信頼区間(fun.data = “mean_cl_normal”)
R
(g7 <- g5 +#平均値のプロット
stat_summary(aes(x = as.numeric(pre_post) + 0.07),
fun.data = "mean_cl_normal",
fun.args = list(conf.int = 0.95),#信頼区間のときに使用する
geom = "errorbar",
width = 0.1,#ひげの横幅
lwd = 1,#ひげの棒の幅
position = pos1
))
data:image/s3,"s3://crabby-images/32964/329647ed217d43a253682776b69401a018c9766d" alt=""
標準偏差
R
(g8 <- g5 +
stat_summary(aes(x = as.numeric(pre_post) + 0.07),
fun.min=function(x) mean(x)-sd(x),
fun.max=function(x) mean(x)+sd(x),
geom = "errorbar",
width = 0.1,#ひげの横幅
lwd = 1,#ひげの棒の幅
position = pos1
))
data:image/s3,"s3://crabby-images/90f1f/90f1fea125ecb5b5cff7be82aada2b262e0b11b9" alt=""
治療Aと治療Bのそれぞれの前後差をt検定(独立した4群と仮定)
R
t.test(value ~ pre_post , data =dat[dat$treat=="A",])$p.value
t.test(value ~ pre_post , data =dat[dat$treat=="B",])$p.value
data:image/s3,"s3://crabby-images/f93a1/f93a1693d0f3bb1b99d6e31e31a5515dfed32c29" alt=""
治療Aは有意差あり(**)、治療Bは有意差なし(N.S.)
R
(g9 <- g8 +
ggsignif::geom_signif(
stat = "identity",
data = data.frame(
x = c(0.87, 1.12),
xend = c(1.87, 2.12),
y = c(9, 12),
annotation = c("**", "N.S.")
),
aes(
x = x,
xend = xend,
y = y,
yend = y,
annotation = annotation
),
col = c("red","#20B2AA")
)
) + ylim (-5,13) + theme_bw()
data:image/s3,"s3://crabby-images/95e77/95e7762a6d125d93648c2560579682d879c39944" alt=""
コメント欄 『間違い』や『分かりにくい部分』などのご意見もお寄せください