ggplot2を使わずbeeswarmをつかったドットプロットをわかりやすく説明しました。とても簡単ですが、魅力的な図ができます。
これは私がまだRを触ったことがなかった時、自分が必要に迫られて短時間でドットプロットを書かなくてはいけなかった際、有料ソフトを購入するしかないと諦めていたときに無料で出来る見つけ使った方法です。
そのため、はじめてRを触った人でも真似をすれば出来る方法を紹介します。
ggplot2を使った方法を参照したい方はこちらを参照してください。
data:image/s3,"s3://crabby-images/95cd0/95cd08c9a55e182ee519f7514b961eda64acdc7c" alt=""
data:image/s3,"s3://crabby-images/4eb8b/4eb8b84700cfc26d5385dcfa20e2f1189c1c637b" alt=""
データセットの準備とbeeswarmのインストール
まずははじめに作業ディレクトリをセットします。
setwd("~/Rpractice/")
beeswarmのパッケージをインストールしましょう。
install.packages("beeswarm", dependencies = TRUE)
beeswarmを起動します。
library(beeswarm)
アヤメデータを使います。アヤメデータについてはこちらで説明をしています。
data:image/s3,"s3://crabby-images/95cd0/95cd08c9a55e182ee519f7514b961eda64acdc7c" alt=""
a <- iris
head(a)
> head(a)
Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1 5.1 3.5 1.4 0.2 setosa
2 4.9 3.0 1.4 0.2 setosa
3 4.7 3.2 1.3 0.2 setosa
4 4.6 3.1 1.5 0.2 setosa
5 5.0 3.6 1.4 0.2 setosa
6 5.4 3.9 1.7 0.4 setosa
>
アヤメデータがaに格納されました。これで準備ができました。
箱ひげ図を書く
まずは単純な箱ひげ図をかいていきます
boxplot(a$Sepal.Length ~ a$Species)
data:image/s3,"s3://crabby-images/de5ae/de5aecde78edf285d5481efd1292c428e955b09a" alt=""
ラベルをつけていきましょう
boxplot(a$Sepal.Length ~ a$Species,
xlab = "Species", ylab = "Sepal Length")
data:image/s3,"s3://crabby-images/97a31/97a316471ae35de70d64a25bce82fa4fbc1d8b87" alt=""
箱ひげ図のかき方はこちらでもいいです。
boxplot(data = a, Sepal.Length ~ Species)
x軸の順番を変えたい時はfactorとlevelを追記します
x軸の順番を変える時、factor()の中にlevel=c()で下のように順番を指定します。
boxplot(a$Sepal.Length ~ factor(a$Species,
level = c('versicolor', 'setosa', 'virginica')),
xlab = "Species", ylab = "Sepal Length")
data:image/s3,"s3://crabby-images/c9664/c966470f610dd7fb5ceb67c9025e8da18b3eb60c" alt=""
colで箱の中を白くします
boxplot(data = a, Sepal.Length ~ Species,
col = "white")
data:image/s3,"s3://crabby-images/1bbfa/1bbfa6366123125fba2a504d90b887c09d145eb8" alt=""
lasで軸の文字の向きを変えることができます
boxplot(data = a, Sepal.Length ~ Species,
col = "white", las = 1)
data:image/s3,"s3://crabby-images/f4b07/f4b0754b41943e009fc028628dbe94ba74fa621c" alt=""
boxplot(data = a, Sepal.Length ~ Species,
col = "white", las = 2)
data:image/s3,"s3://crabby-images/c067d/c067d1bfb8fc1ea09b18335ebabd2158ad12aa8d" alt=""
下の文字が重なってしまいましたね。
ボックスプロットを横向きにします
boxplot(data = a, Sepal.Length ~ Species,
col = "white",
horizontal = TRUE, las = 2)
data:image/s3,"s3://crabby-images/fe9cc/fe9cc38aae1d4ee73985f277802d6c8e4d549848" alt=""
横の文字が重なったのと、2番目の文字列が長すぎてきれてしまいました。初心者向けの記事なので、シンプルにアノテーションをなしにして、また少し外側のスペースを増やしましょう。
par(mar = c(5,5,4,2) + 0.1) # default is c(5,4,4,2) + 0.1
boxplot(data = a, Sepal.Length ~ Species,
col = "white",
horizontal = TRUE, ann = FALSE, las = 2)
data:image/s3,"s3://crabby-images/3efde/3efde18fd6deab14785167f66132a6424942da33" alt=""
beeswarmを箱ひげ図にのせていく
beeswarmを使っていきます
ようやくbeeswarmにたどり着きました。
beeswarm(data = a, Sepal.Length ~ Species)
data:image/s3,"s3://crabby-images/22013/220134d13b4f0d64c49a4fe6fdefefec99639d16" alt=""
beeswarmでadd = TRUEとすると下の図に重ねることができます
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species, add = TRUE)
data:image/s3,"s3://crabby-images/5707e/5707e49fdaf66ecdf6cafbe2ce0a38def12b3366" alt=""
色をつけます
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species,
col = c("red","blue","green"),
add = TRUE)
data:image/s3,"s3://crabby-images/168ec/168ec93ac6e2bbba9b003ccc0b7c9c221170ba8b" alt=""
ドットのスタイルを変えるにはpchを指定します。
pchには25種類用意されています
data:image/s3,"s3://crabby-images/17df6/17df6dfff1199534ddf000bfa477a91ef87bcb4e" alt=""
pchを19に指定してみます。好みで選んでください。ちなみに16と19の丸の違いですが、16は普通の丸、19は少し斜め方向に膨らんだような丸になっています。
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species,
col = c("red","blue","green"),
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/cc69d/cc69d4ea3bd66853be71448c5b8d03b30e62b5a3" alt=""
cexでドットの大きさを変えます。
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species,
method = "swarm",
col = c("red","blue","green"),
pch = 19,
cex = 1.3,
add = TRUE)
data:image/s3,"s3://crabby-images/eeb55/eeb550072b21c1cd7ffd9e43ea6669486e153ade" alt=""
spacingで点と点の距離を変更できます
data:image/s3,"s3://crabby-images/e4a63/e4a63af684226d463d125005f2d721b3ea600403" alt=""
beeswarmのmethodは4つある
swarm, center, hex, squareの4つあります
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species,
method = "swarm",
col = c("red","blue","green"),
pch = 19,
cex = 1.3,
add = TRUE)
data:image/s3,"s3://crabby-images/60b8b/60b8ba365f3e3f034a5b42430c925612ba4a3956" alt=""
boxplot(data = a, Sepal.Length ~ Species, col = "white", las = 1)
beeswarm(data = a, Sepal.Length ~ Species,
method = "center",
col = c("red","blue","green"),
pch = 19,
cex = 1.3,
add = TRUE)
data:image/s3,"s3://crabby-images/9429e/9429e2928baa8494e1eef77432e38e1686bfbe00" alt=""
アヤメデータは小数点1桁までなので、methodによる違いがあまりはっきりしません。
rnormで乱数をつくってみます
x <- rnorm(100, 10, 10)
y <- rnorm(100, 25, 10)
z <- rnorm(100, 20, 15)
それぞれのmethodによるグラフの違いをみていきましょう
methodによる違い
もう一度methodの違いを見ていきます
swarm
boxplot(list(x, y, z), col = "white", las = 1)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
spacing = 0.6,
cex = 1.3,
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/8d6b7/8d6b76003fb34da294843a176beac1018386fd3d" alt=""
center
boxplot(list(x, y, z), col = "white", las = 1)
beeswarm(list(x, y, z),
method = "center",
col = c("red","blue","green"),
spacing = 0.9,
cex = 1.3,
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/a1508/a1508483006ab39c6faa5e5ab814807f4086c507" alt=""
hex
boxplot(list(x, y, z), col = "white", las = 1)
beeswarm(list(x, y, z),
method = "hex",
col = c("red","blue","green"),
spacing = .9,
cex = 1.3,
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/254d6/254d647d48678b441bb3e6db71c7252ad0a34efe" alt=""
square
boxplot(list(x, y, z), col = "white", las = 1)
beeswarm(list(x, y, z),
method = "square",
col = c("red","blue","green"),
cex = 1.3,
spacing = .9,
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/30dea/30dea2b57ce3985b00fc5ddc28aeb24e8c57cad1" alt=""
ラベルを変えてみます
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
spacing = .6,
priority = "density",
add = TRUE)
data:image/s3,"s3://crabby-images/59c8b/59c8ba34bacc4585cb54e9579636339944625334" alt=""
その他の機能を簡単に紹介します
corral
corralは点が大きく外側に外れたものを調整する方法です。
“none”, “gutter”, “wrap”, “random”, “omit”の5つの方法があります。
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
corral = "wrap",
cex = 1.3,
spacing = .9,
pch = 19,
add = TRUE)
data:image/s3,"s3://crabby-images/2c62e/2c62e11f50deccf3d75825e2baa4888fcd019fbd" alt=""
priority
点の配置ですが、実際に見てみたほうがわかりやすいです。
descending
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
cex = 1.3,
spacing = .9,
priority = "descending",
add = TRUE)
data:image/s3,"s3://crabby-images/960e7/960e72a05fce529e3792b2f339ac8f22b62a09ab" alt=""
random
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
spacing = .9,
priority = "random",
add = TRUE)
data:image/s3,"s3://crabby-images/0259f/0259f1ca277adab7b31f8859127501cf3a457d58" alt=""
density
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
spacing = .9,
priority = "density",
add = TRUE)
data:image/s3,"s3://crabby-images/dd4f7/dd4f7209a26f3164c09647cb462f079c694ff10e" alt=""
side
点を右側か左側に集めます。
side = 1
右側に集めます。
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
spacing = .9,
side = 1,
add = TRUE)
data:image/s3,"s3://crabby-images/a9238/a9238ce206baeec0c79965919923892c75c413c2" alt=""
side = -1
左側に集めます。
boxplot(list(x, y, z),
names = c("A", "B", "C"),
xlab = "Names",
ylab ="Values",
col = "white",
las = 1,
cex.lab = 1.5,
cex.axis = 1.5)
beeswarm(list(x, y, z),
method = "swarm",
col = c("red","blue","green"),
pch = 19,
spacing = .9,
side = -1,
add = TRUE)
data:image/s3,"s3://crabby-images/a7189/a718931b56184d93ca6d39eea8613535dfa4faa3" alt=""
無料のオープンソースでここまでできるのはすごいですよね。
ggplot2とggbeeswarmを使った方法はこちらで紹介をしています。
どちらがいいかは好みですので、どちらでも使いやすいほうを使うのがいいと思います。
data:image/s3,"s3://crabby-images/4eb8b/4eb8b84700cfc26d5385dcfa20e2f1189c1c637b" alt=""
お役に立ちましたら幸いです。