0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

機械学習入門 vol.9 判別(分類)

Last updated at Posted at 2021-12-13

本コンテンツは機械学習入門講座を各所でやっている内容の一部を、受講者の皆様の予習・復習のために公開しているものです。対象読者は、Pythonをやったことがほとんどない方やつまづいてしまっている方でも概ね実行できるようになるレベルで書いています。解説は講座でそれなりに詳しくしているため、コードにコメントする以上の説明はあまり記述していません。

各コードはJupyterシリーズやiPythonで記述しながら実行できるように記述しています。

AI/DX/機械学習/Pythonのアドバイザリー、社内研修、セミナー等承っております。
webサイトからお問い合わせください。
BeeComb Grid株式会社

機械学習入門シリーズ記事

  1. 機械学習入門 vol.1 Pythonの基礎1 記述とデータ型 -> 講座第3回に相当
  2. 機械学習入門 vol.2 Pythonの基礎2 条件分岐と処理 -> 講座第3回に相当
  3. 機械学習入門 vol.3 Pythonの基礎3 関数・クラス・モジュール -> 講座第3回に相当
  4. 機械学習入門 vol.4 表(Pandas)の基本操作 -> 講座第3回/第4回に相当
  5. 機械学習入門 vol.5 グラフ(Seaborn)の基本操作 -> 講座第3/4回に相当
  6. 機械学習入門 vol.6 回帰 - 線形回帰 -> 講座第4回に相当
  7. 機械学習入門 vol.7 回帰 - ランダムフォレストとパラメータチューニング -> 講座第4回に相当
  8. 機械学習入門 vol.8 回帰 - その他の回帰 (k近傍法,ラッソ回帰,リッジ回帰..etc) -> 講座第4回に相当
  9. 機械学習入門 vol.9 判別(分類) -> 講座第5回に相当
  10. 機械学習入門 vol.10 次元削減 -> 講座第6回に相当
  11. 機械学習入門 vol.11 クラスタリング -> 講座第6回に相当

機械学習入門 vol.9 判別(分類)

第5回の講座では、判別(分類)についての基礎原理と各アルゴリズムの説明をさせていただき、サポートベクターマシン分類器(SVC)、ランダムフォレスト分類器(RandomForestClassifier)、k近傍法分類器(KNeighborsClassifier)を利用して分類の実践を行いました。

本ページのプログラムは、プログラム実行ファイルと同じフォルダに下記データファイルが保存されていることを前提として書いています。ダウンロードしてご利用ください。

データ -> data2.xlsx

最初に必要なライブラリのインポートとデータの読み込みをしておきます。またグラフで日本語が文字化けしないように画像・グラフライブラリで利用するフォントを設定しておきます。

# Pandas - データ操作ライブラリ
import pandas as pd
# サポートベクターマシン分類器
from sklearn.svm import SVC
# ランダムフォレスト分類器
from sklearn.ensemble import RandomForestClassifier
# k近傍法分類器
from sklearn.neighbors import KNeighborsClassifier
# テストデータセット分割関数
from sklearn.model_selection import train_test_split
# グラフライブラリ Seaborn
import seaborn as sb
# 描画ライブラリ matplotlib
import matplotlib as mpl
# 描画時のフォントファミリーを設定
mpl.rcParams['font.family'] = 'Hiragino Maru Gothic Pro'
sb.set(font=['Hiragino Maru Gothic Pro'])
# データを読み込み
df = pd.read_excel('./data2.xlsx', sheet_name='データ')
df

image.png

# 名前とクラスを削除
df = df.drop("名前", axis=1)
df = df.drop("クラス", axis=1)
# ペアプロットで描画
sb.pairplot(data=df, hue='分類')
# データフレームからトレーニング用データと正解ラベルを配列で取り出し
data   = df.loc[:,'国語':'週の学習時間'].values
labels = df['分類']
# データをトレーニング用と検証用に分割
train_data, test_data, train_labels, test_labels = train_test_split(data, labels, test_size=0.2)
train_data
# サポートベクターマシン
svmc = SVC(gamma="scale")
svmc.fit(train_data, train_labels)
# ランダムフォレスト分類器
forest = RandomForestClassifier()
forest.fit(train_data, train_labels)
# K近傍法
knn = KNeighborsClassifier(n_neighbors=6)
knn.fit(train_data, train_labels)
# 検証用データをデータフレーム化
df = pd.DataFrame(test_data, columns=['国語','算数','英語','理科','社会','合計点数','週の学習時間'])
df['分類'] = test_labels.values
# サポートベクターマシンで予測
preds_svmc = svmc.predict(test_data)
df['SVM予測分類'] = preds_svmc
# ランダムフォレストで予測
preds_rf = forest.predict(test_data)
df['RF予測分類'] = preds_rf
# k近傍法で予測
preds_knn = knn.predict(test_data)
df['KNC予測分類'] = preds_knn
# 表示
df

精度検証

回帰の場合は、学習済みモデルを使った予測が正解とどれだけずれているかの差分を可視化することで精度の検証を行うことができました。判別(分類)の場合は、ビジネスシーンや用途に応じて考えなければいけない精度の概念の説明をさせていただき、適合率(Precision)、再現率(Recall)、F値(F-Measure)について説明させていただきました。

image.png

最初に単純に正答率を確認するには下記のように行うことができました。

# 正確性を計算する
from sklearn.metrics import accuracy_score
accuracy_score(test_labels.values, preds_svmc)

適合率(P値 / Precision)

# P値(Precision・適合率)を計算する
from sklearn.metrics import precision_score
precision_score(test_labels.values, preds_svmc, average=None)
precision_score(test_labels.values, preds_rf, average=None)
precision_score(test_labels.values, preds_knn, average=None)

再現率(R値 / Recall)

# R値(Recall・再現率)を計算する
from sklearn.metrics import recall_score
recall_score(test_labels.values, preds_svmc, average=None)
recall_score(test_labels.values, preds_rf, average=None)
recall_score(test_labels.values, preds_knn, average=None)

F値(F-measure)

# F値(精度と再現率の調和平均)を計算する
from sklearn.metrics import f1_score
f1_score(test_labels.values, preds_svmc, average=None)
f1_score(test_labels.values, preds_rf, average=None)
f1_score(test_labels.values, preds_knn, average=None)

PrecisionとRecallは基本的にはトレードオフとなるお話をさせていただき、P値は予測したものの中に間違ったデータが分類に含まれてしまうケースを表す値、R値は本来予測に入れるべきデータが予測の中から漏れてしまうケースを表す値であり、F値をあげられなくてもユースケースに応じてどちらを重視するかで調整をかければ利用できる可能性があるという流れになるということを覚えておいていただければと思います。

機械学習入門シリーズ記事

  1. 機械学習入門 vol.1 Pythonの基礎1 記述とデータ型 -> 講座第3回に相当
  2. 機械学習入門 vol.2 Pythonの基礎2 条件分岐と処理 -> 講座第3回に相当
  3. 機械学習入門 vol.3 Pythonの基礎3 関数・クラス・モジュール -> 講座第3回に相当
  4. 機械学習入門 vol.4 表(Pandas)の基本操作 -> 講座第3回/第4回に相当
  5. 機械学習入門 vol.5 グラフ(Seaborn)の基本操作 -> 講座第3/4回に相当
  6. 機械学習入門 vol.6 回帰 - 線形回帰 -> 講座第4回に相当
  7. 機械学習入門 vol.7 回帰 - ランダムフォレストとパラメータチューニング -> 講座第4回に相当
  8. 機械学習入門 vol.8 回帰 - その他の回帰 (k近傍法,ラッソ回帰,リッジ回帰..etc) -> 講座第4回に相当
  9. 機械学習入門 vol.9 判別(分類) -> 講座第5回に相当
  10. 機械学習入門 vol.10 次元削減 -> 講座第6回に相当
  11. 機械学習入門 vol.11 クラスタリング -> 講座第6回に相当

AI/DX/機械学習/Pythonのアドバイザリー、社内研修、セミナー等承っております。
webサイトからお問い合わせください。
BeeComb Grid株式会社

0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?