LoginSignup
4
1

More than 1 year has passed since last update.

都道府県を各コンビニ店舗数で分類してみた!!!(R言語、クラスター分析)

Last updated at Posted at 2021-12-19

はじめに

この記事は R Advent Calendar 2021の20日目の記事です。
よろしくお願いします。

概要

今回の記事はR Advent Calendar 2021 3日目の記事である都道府県の人口密度と相関が高いコンビニはどこだ!!!(R言語、無相関検定)の派生です。
前回はコンビニ各社の中で人口密度を相関の高いコンビニを見つけましたが、今回は各コンビニの店舗数から都道府県を分類するクラスター分析を行います。

クラスター分析とは

クラスター分析(cluster analysis)とは、「類似のデータをいくつかのグループに分類する」多変量解析です。クラスター分析でデータを分類する難易度は、明確な分類基準の有無に依存します。
クラスター分析では、分類基準となる変数の数値(今回はコンビニ店舗数)を用いて、各都道府県が「どの程度似ているか」という類似度(similarity)または、「似ていないか」という非類似度(dissimilarity)を算出し、これらをもとに都道府県をグループ(クラスター)に分類します。

準備(R編)

クラスター分析を行い、デンドログラム(樹形図)を作成するためにR言語を使用します。
R言語を使用するために統計解析用ソフトであるR、RStudioをダウンロードする必要があります。
どちらもフリーソフトで、下記のURLからダウンロードできます。

R https://cran.r-project.org/
RStudio https://www.rstudio.com/products/rstudio/download/#download

準備(元データ編)

基本的には前回の記事と同じデータを使います。
元データの各都道府県別のコンビニ各社の店舗数は下記のURLを参照しました。

都道府県データランキング https://uub.jp/pdr/m/c.html

実際に用いた元データは下のとおりです。
image.png
RStudioに読み込むためにcsv形式に出力しておきましょう。

デンドログラム作成(RStudio)

  1. RStudioを立ち上げます。 下のようなConsoleが出てくると思います。 コマンドは赤い丸で示している「>」の隣に書きます。

image.png

2. RStudio作業用ディレクトリの確認もしくは変更します。
作業用ディレクトリ確認コマンド

getwd()

作業用ディレクトリ変更コマンド

 setwd("パス名")

作業用ディレクトリ確認コマンドをConsoleに打ち込みます。
作業用ディレクトリが分かるので、そのディレクトリにcsv形式の元データを入れておきます。
もしくは、setwd("パス名")で作業用ディレクトリを変更可能です。

3. Rstudioに元データを読み込み
先にcsv形式の元データを作業用ディレクトリに入れておきます。
その後、Consoleに下記のコマンドを打ち込みます。

 (データ名)<-read.csv("(ファイル名)",header=T)

実際の画面は下のとおりです。
保存するデータ名を「data1001」にして、元データのファイル名は「data1001.csv」で保存していたので、下のようになります。
  image.png
header=Tとなっていますが、これは元データの「都道府県」や「セブンイレブン」といったセルをデータと認識させないためです。
すると、元データがRStudioに取り込まれます。
image.png

4. 非類似度の導出
データの非類似度を導出するコマンド 

dist()

実際の画面は下のとおりです。
data1001の1列目は都道府県名を書いているので、data1001[,2:11]と指定します。
変数distanceに非類似度を代入しておきます。
image.png

5. デンドログラム作成
デンドログラム作成コマンド 

hclust(distance, "ward.D2")

上記でdistanceに非類似度を代入しています。
ward.D2はクラスター間の距離算出方法の一つであるウォード法を示しています。
image.png
plotより下のようなデンドログラムが作成できます。
image.png
しかし、これではどの数字がどの都道府県かわからないため、下の処理をします。
都道府県名を記入し、見やすくなります。
image.png
これによりわかりやすいデンドログラムが作成できます。
コンビニ_デンドログラム.png
都市と田舎で大きくわかれ、あんまり同じ地域で固まりすぎていないと確認できます。
デンドログラムを適当な距離で切断するために下記の関数を用います。
クラスター分割関数 

cutree()

分割するデンドログラムの高さを800とすると、下のとおりになります。
image.png
h=をk=とすることで、分割するクラスターの個数に変更できます。
分割のイメージは下のとおりです。
image.png
下のおまけに色分けした日本地図があるので、ぜひそちらをどうぞ。

まとめ

・都道府県を各コンビニ店舗数でクラスター分析しました。
・結果としては、地域で都道府県が固まるわけではなく、大きく分割すると、「都市」と「田舎」にわかれました。

おまけ(日本地図に塗り分け)

上記の区分に基づいて都道府県を色分けしました。
用いたサイトは下記のとおりです。
  
  日本地図|白地図ぬりぬり https://n.freemap.jp/tp/Japan

  20211210_142737117.png

あとがき

今回は、前回のコンビニと人口密度から派生して、都道府県をコンビニで分類してみました。
都市と田舎に大きくはわかれました。
他のジャンルのチェーン店でやったりするのも面白そうだと思いました。
R Advent Calendar 2021の3日目と20日目の2日書かせていただきありがとうございます。

お読みいただきありがとうございました。

  

4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1