ggplot2を使って、散布図を書きたい。
という悩みを解決します。
今回は、ggplot2を使って散布図をつくります。テーマ別に作り方がかいてあるので、必要なところだけ、ご覧ください。
散布図をつくる目的・実行環境
目的
散布図を使って、データを可視化する。
実行環境
- Windows10
- Rstudio
MacでもLinuxでも可です。
散布図をつくる
使うデータ
使うデータは、gcookbookパッケージのデータ【heightweight】を使います。各自のデータがある方は、そちらを使ってください。
【heightweight】のデータの概要はこんな感じです。
data:image/s3,"s3://crabby-images/e41e3/e41e3b77a7a2ce76f02661e491e3031a9e4f3eb2" alt="散布図"
必要なパッケージ
- ggplot2
- gcookbook(データがある方は必要ない)
この2つを使います。パッケージの使い方がわからない方は、【R】RStudioでパッケージをインストールする方法と読み込みまでの流れをご覧ください。
先にパッケージを読み込みましょう。
library(ggplot2)
library(gcookbook)
シンプルな散布図
シンプルな散布図をつくる
ggplot(heightweight,aes(x=ageYear,y=heightIn))+geom_point()
ggplot(データ名,aes(x=x軸にしたいデータ,y=y軸にしたいデータ)) + geom_point
data:image/s3,"s3://crabby-images/3a354/3a354c287b08a00d7ca5ae5d8de5a86dfd2bfb14" alt="散布図"
ポイント(点)の大きさを変える
ggplot(heightweight,aes(x=ageYear,y=heightIn))+geom_point(size=5)
ggplot(heightweight,aes(x=ageYear,y=heightIn))+geom_point(size=数字)
size=数字 | ポイントの大きさを変える |
data:image/s3,"s3://crabby-images/2bf0d/2bf0d9b219e3dcc8923e1587b676ba8dd25afbc1" alt="散布図"
ポイント(点)の形を変える
ggplot(heightweight,aes(x=ageYear,y=heightIn))+geom_point(shape=0)
ggplot(heightweight,aes(x=ageYear,y=heightIn))+geom_point(shape=数字)ここの数値を変えると形が変わる0~25
shape=数字 | ポイントの形を変える |
data:image/s3,"s3://crabby-images/72c85/72c858e70b15874ee0b46869690e8bbef512bde5" alt="散布図"
3つの変数を使う
色分けして散布図にする
性別ごとに分けたりすることですね。
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex))+geom_point()
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex))+geom_point()
↑変数を入れる
colour=データ名 | 分けたい変数名をいれる |
data:image/s3,"s3://crabby-images/e7d8f/e7d8f30adafe6d81b6c6e367e6984fa125f27a60" alt="散布図"
形分けして散布図にする
色ではなく、形で分けます。
ggplot(heightweight,aes(x=ageYear,y=heightIn, shape=sex))+geom_point()
ggplot(heightweight,aes(x=ageYear,y=heightIn, shape=sex))+geom_point()
↑グループ化したいデータを入れる
shape=変数 | わけたい変数をいれ、形によって分類される |
data:image/s3,"s3://crabby-images/c14e2/c14e2a446a69ff62003b617fe0ed8f143d69c01d" alt="散布図"
色分けして形かえて散布図
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex,shape=sex))+geom_point()
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex,shape=sex))+geom_point()
colour=sex,shape=sex | 形と色で分かれる |
data:image/s3,"s3://crabby-images/bbd4a/bbd4a82ca3eaa256fe7b242e7051147030b581dd" alt="散布図"
ポイントの形を変える
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex,shape=sex))+geom_point() +
scale_shape_manual(values = c(2,4))
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex,shape=sex))+geom_point() +
scale_shape_manual(values = c(2,4))
scale_shape_manual(values = c(数字,数字)) | グループ化した変数の形を変える |
data:image/s3,"s3://crabby-images/4e37b/4e37bfab34b74cee9573b349a5a0152e193c6483" alt="散布図"
ポイントの色を変える
通常のままだとわかりにくいので、色を変えていきます。
ggplot(heightweight,aes(x=ageYear,y=heightIn, colour=sex,shape=sex))+geom_point() +
scale_color_brewer(palette = "Dark2")
↑ポイントの色を変えています。
scale_color_brewer(palette = "色") | ポイントの色を変える |
この色というのは、こんだけ種類があります。好きな色に分けてみてください。
data:image/s3,"s3://crabby-images/e928b/e928b6f432d44cf276a6401464e4d9be1d0393ce" alt="散布図"
data:image/s3,"s3://crabby-images/1737d/1737d2f4bfba1161519e7327f071c2282189d5da" alt="wordcloud"
3つ目の連続値変数を使った散布図
身長が高くなるごとに、体重が増加することを色やポイントの大きさを使って、表していきたい場合に使います。
数値と色が比例
ggplot(heightweight,aes(x=ageYear,y=heightIn,fill=weightLb)) +
geom_point(shape=21, size=2.0) +
scale_fill_gradient(low = "red",high = "white")
ggplot(heightweight,aes(x=ageYear,y=heightIn,fill=weightLb)) +
geom_point(shape=21, size=2.0) +
scale_fill_gradient(low = "red",high = "white")
↑fillで入れた変数が高くなるほど、白、低くなるほど、赤になる
scale_fill_gradient(low = "色",high = "色") | fillの数値に対応している。fillでいれた変数の値が小さいほど、lowの色に近づき、高くなるほど、highの色に近づく |
data:image/s3,"s3://crabby-images/53a14/53a14ff6b435807f7165088c4d2e44b4afb69a3b" alt="散布図"
数値と大きさが比例
ggplot(heightweight,aes(x=ageYear,y=heightIn,size=weightLb))+
geom_point(alpha=0.4)+
scale_size_area()
ggplot(heightweight,aes(x=ageYear,y=heightIn,size=weightLb))+
geom_point(alpha=0.4)+
scale_size_area()
scale_size_area()でsizeの値が比例する(ポイントが大きくなる)
scale_size_area() | sizeの値と比例して、ポイントが大きくなる |
alpha=数値 | 明度0~1まで(色の透明度を表す) |
data:image/s3,"s3://crabby-images/68d99/68d998ed324fd10e840dcb28c6d759a6e67839de" alt="散布図"
色と値と大きさで散布図
日本語で上手く表すことができなくてすいません。
ggplot(heightweight,aes(x=ageYear,y=heightIn,size=weightLb,colour=sex))+
geom_point(alpha=0.4)+
scale_size_area()+
scale_color_brewer(palette = "Set2")
ggplot(heightweight,aes(x=ageYear,y=heightIn,size=weightLb,colour=sex))+
geom_point(alpha=0.4)+
scale_size_area()+
scale_color_brewer(palette = "Set2")
scale_size_area() | sizeの値と比例して、ポイントが大きくなる |
scale_color_brewer(palette = "色") | ポイントの色が変わります |
data:image/s3,"s3://crabby-images/a397c/a397caca63098aefcc653072ece07aa1273664f2" alt="散布図"
色はこれです。
data:image/s3,"s3://crabby-images/1737d/1737d2f4bfba1161519e7327f071c2282189d5da" alt="wordcloud"
まとめ
size=数字 | ポイントの大きさを変える |
shape=数字 | ポイントの形を変える |
colour=データ名 | 分けたい変数名をいれる |
shape=変数 | わけたい変数をいれ、形によって分類される |
colour=sex,shape=sex | 形と色で分かれる |
scale_shape_manual(values = c(数字,数字)) | ポイントの形を変える |
scale_color_brewer(palette = “色”) | ポイントの色を変える |
scale_fill_gradient(low = “色”,high = “色”) | fillの数値に対応している。fillでいれた変数の値が小さいほど、lowの色に近づき、高くなるほど、highの色に近づく |
scale_size_area() | sizeの値と比例して、ポイントが大きくなる |
alpha=数値 | 明度0~1まで(色の透明度を表す) |
以上ggplot2をつかって散布図を様々な方法でした。
data:image/s3,"s3://crabby-images/5b545/5b54521ca102ce2194289e6ac30d56cf22ceae20" alt=""
参考文献
Rグラフィックスクックブックを参考にこの記事を書かせていただきました。とても参考になるので、Rでグラフ作成をしたい人は是非、購入してみてください。
コメント