Rでヒストグラムと箱ひげ図をggplot2 を使って重ねて描く方法の紹介。
Rでヒストグラムをggplot2 を使って描く方法
Rでヒストグラムをggplot2を使って描く方法を紹介する。
まずggplot2 パッケージをインストールして、呼び出しておく。
install.packages("ggplot2")
library(ggplot2)
次にヒストグラムを描くデータを準備する。
今回は pROC パッケージの aSAH データセットを使用する。
aSAH データセットの中の age のヒストグラムを描くことにする。
pROC パッケージをインストールして、呼び出す。
install.packages("pROC")
library(pROC)
通常のヒストグラムはこんな感じになる。
hist(aSAH$age)
data:image/s3,"s3://crabby-images/c0440/c0440a9af67627deadb7399dd16ca01baccccb4a" alt=""
ggplot2で描くとこんなかっこいい感じに描ける。
ggplot(aSAH, aes(x=age)) + geom_histograpm()
data:image/s3,"s3://crabby-images/bd537/bd53757824ebf2fcb4adf528380b0df0018ce276" alt=""
Rで箱ひげ図をggplot2 を使って描く方法
Rで箱ひげ図を ggplot2 を使って描く方法を紹介する。
通常の箱ひげ図は、こんな感じになる。
boxplot(aSAH$age)
data:image/s3,"s3://crabby-images/6193b/6193bfcf036b3a37483d50a3585cde13b1510b4a" alt=""
ggplot2 を使って描くとこういうふうになる。
ggplot(aSAH, aes(x=1, y=age)) + geom_boxplot()
data:image/s3,"s3://crabby-images/fe5e5/fe5e575000c53dd28eb19ae26b84e48f2fdf8f45" alt=""
これを横にすることができる。
ggplot(aSAH, aes(x=1, y=age)) + geom_boxplot() + coord_flip()
data:image/s3,"s3://crabby-images/70f99/70f99704bd6a9cdc3a680b174e03ae8b0a0f0ebd" alt=""
Rでヒストグラムと箱ひげ図を ggplot2 で重ねて描く方法
上記のヒストグラムにHist1という名前を付けて、箱ひげ図には Box1 という名前を付けて、上下に並べて描くスクリプトを示す。
Hist1 <- ggplot(aSAH, aes(x=age))+
geom_histogram()
Box1 <- ggplot(aSAH, aes(x=1, y=age))+
geom_boxplot()+
coord_flip()
grid.arrange(Hist1, Box1, ncol=1, nrow=2)
grid.arrange() というのが並べる関数で、ncol=が列のグラフ枠の数、nrow=が行のグラフ枠の数である。
すると以下のような図が描ける。
data:image/s3,"s3://crabby-images/3b4c5/3b4c563b17b3fdd27133427dbd475a3e76bc2d20" alt=""
ここからもう少しきれいにしていく。
スクリプト内に注釈を入れて、どの行が何をしているのかわかるようにしておく。
x <- aSAH$age
Mean <- mean(x)
Lim <- c(min(x)-sd(x)/2, max(x)+sd(x)/2) #X軸の最小最大の設定
Hist2 <- ggplot(aSAH, aes(x=age))+
geom_histogram(fill = "darkgray")+ #ヒストグラムを薄いグレーで塗る
geom_vline(xintercept = Mean, color="black")+ #平均値の位置に縦の線を黒で描く
coord_cartesian(xlim = Lim) #X軸の設定をここで反映
Box2 <- ggplot(aSAH, aes(x=1, y=age))+
geom_boxplot()+
coord_flip(ylim = Lim)+ #グラフを横にしているので横軸のY軸の設定
theme(axis.text.y = element_text(color="white"))+ #横にした後の縦方向の軸の文字を白にして非表示に
labs(x="") #縦方向の軸のラベルを非表示に
grid.arrange(Hist2, Box2, ncol=1, nrow=2, heights=c(4,1)) #heights で下の部分の高さを1/4に
実行するとこんなグラフになる。
data:image/s3,"s3://crabby-images/37688/37688dc0c1d6f6059dccd3540f03a04947211d2c" alt=""
上下を入れ替えるとこんなふうになる。
grid.arrange(Box2, Hist2, ncol=1, nrow=2, heights=c(1,4))
data:image/s3,"s3://crabby-images/98001/98001fd187d00bb5aae6e3fc7dcb4133f2a458e3" alt=""
箱ひげ図のラベルを消すともっと見栄えがいいかもしれない。
Box2 <- ggplot(aSAH, aes(x=1, y=age))+
geom_boxplot()+
coord_flip(ylim = Lim)+
theme(axis.text.y = element_text(color="white"))+
labs(x="", y="") # y="" を追加
grid.arrange(Box2, Hist2, ncol=1, nrow=2, heights=c(1,4))
data:image/s3,"s3://crabby-images/dae89/dae898e0e8a4d86e907b15c37ec8162ef2050aaf" alt=""
箱ひげ図に theme_minimal() を適用するとシンプルでみやすくなる。
Box2 <- ggplot(aSAH, aes(x=1, y=age))+
geom_boxplot()+
coord_flip(ylim = Lim)+
theme_minimal()+ #この行を追加
theme(axis.text.y = element_text(color="white"))+
labs(x="", y="")
grid.arrange(Box2, Hist2, ncol=1, nrow=2, heights=c(1,4))
data:image/s3,"s3://crabby-images/56e11/56e1124624754e5066dca6922206d3ace99d8374" alt=""
まとめ
Rでヒストグラムと箱ひげ図を重ねる方法を、ggplot2を使って紹介した。
何らか役に立てば幸い。
コメント