機械学習とデータ マイニングの人気に伴い、ますます多くのデータ サイエンティストや研究者が高級プログラミング言語である Python を使用してデータを処理および分析し始めています。Python の直観性と使いやすさにより、Python は広く使用されています。深さ 学習や人工知能の分野で広く使用されています。ただし、多くの初心者は Python を使用するときにいくつかの問題に遭遇します。その 1 つは混同行列の難しさです。この記事では、Python での混同行列の使用方法と、混同行列を扱うときに役立ついくつかのテクニックを紹介します。
1.混同行列とは
ディープラーニングとデータマイニングにおいて、混同行列とは、予測結果と実際の結果の差異を比較するために使用される長方形のテーブルです。このマトリックスは、分類アルゴリズムの精度、エラー率、精度、再現率などの重要な指標を含む、分類アルゴリズムのパフォーマンスを示します。混同行列は通常、分類器のパフォーマンスを視覚化し、分類器の改善と最適化のための予測結果の主な参照を提供します。
通常、混同行列は 4 つのパラメーターで構成されます。
- 真陽性 (TP): 分類アルゴリズムは、陽性クラスを陽性クラスとして正確に予測します。
- 偽陰性 (FN): 分類アルゴリズムは、陽性クラスを陰性クラスとして誤って予測します。
- 偽陽性 (FP): 分類アルゴリズムは、陰性クラスを陽性クラスとして誤って予測します。
- 真陰性 (TN): 分類アルゴリズムは、陰性クラスを陰性クラスとして正確に予測します。
2. 混同行列の計算方法
Python の scikit-learn ライブラリには、混同行列を計算する便利な関数が用意されています。この関数はconfusion_matrix()と呼ばれ、分類子とテストセットの実際の結果の間の入力として使用でき、混同行列のパラメータ値を返します。この関数の構文は次のとおりです。
from sklearn.metrics import confusion_matrix confusion_matrix(y_true, y_pred, labels=None, sample_weight=None)
このうち、y_true は分類子の正しい結果を表し、y_pred は分類子の予測結果を表し、ラベルはクラス ラベルの名前を表します (指定されていない場合)。 、デフォルトは y_true および y_pred から抽出された値です)、sample_weight は各サンプルの重みを表します (必要ない場合は、このパラメーターを設定しないでください)。
たとえば、次のデータの混同行列を計算する必要があるとします。
y_true = [1, 0, 1, 2, 0, 1] y_pred = [1, 0, 2, 1, 0, 2]
混同行列を計算するには、次のコードを使用できます。
from sklearn.metrics import confusion_matrix cm = confusion_matrix(y_true, y_pred) print(cm)
The出力結果は次のとおりです:
array([[2, 0, 0], [0, 1, 2], [0, 1, 0]])
つまり、混同行列は、「1」が「1」として 2 回正しく分類され、「0」が「0」として 1 回正しく分類され、「2」が正しく分類されていることを示しています。 as "2" 「「1」が「2」と誤分類されるケースが 0 件あり、「2」が「1」と誤分類されるケースが 2 件あり、「0」が「2」と誤分類されるケースが 1 回発生しました。
3. 混同行列を表示する
混同行列をより適切に視覚化する必要がある状況は数多くあります。 Python の matplotlib ライブラリは、混同行列を視覚化できます。以下は、matplotlib ライブラリと sklearn.metrics を使用して混同行列を視覚化する Python コードです。
import itertools import numpy as np import matplotlib.pyplot as plt from sklearn.metrics import confusion_matrix def plot_confusion_matrix(cm, classes, normalize=False, title='Confusion matrix', cmap=plt.cm.Blues): """ This function prints and plots the confusion matrix. Normalization can be applied by setting `normalize=True`. """ if normalize: cm = cm.astype('float') / cm.sum(axis=1)[:, np.newaxis] print("Normalized confusion matrix") else: print('Confusion matrix, without normalization') print(cm) plt.imshow(cm, interpolation='nearest', cmap=cmap) plt.title(title) plt.colorbar() tick_marks = np.arange(len(classes)) plt.xticks(tick_marks, classes, rotation=45) plt.yticks(tick_marks, classes) fmt = '.2f' if normalize else 'd' thresh = cm.max() / 2. for i, j in itertools.product(range(cm.shape[0]), range(cm.shape[1])): plt.text(j, i, format(cm[i, j], fmt), horizontalalignment="center", color="white" if cm[i, j] > thresh else "black") plt.tight_layout() plt.ylabel('True label') plt.xlabel('Predicted label') # Compute confusion matrix cnf_matrix = confusion_matrix(y_test, y_pred) np.set_printoptions(precision=2) # Plot non-normalized confusion matrix plt.figure() plot_confusion_matrix(cnf_matrix, classes=class_names, title='Confusion matrix, without normalization') # Plot normalized confusion matrix plt.figure() plot_confusion_matrix(cnf_matrix, classes=class_names, normalize=True, title='Normalized confusion matrix') plt.show()
上記のコードでは、plot_confusion_matrix() という名前のカスタム関数を定義します。この関数は、混同行列のパラメータ、カテゴリ名のテキスト文字列をパラメータとして受け取り、混同行列をカラー イメージとして出力します。混同行列の各セルの色は、その値のサイズを表します。次に、それぞれの真のカテゴリと予測されたカテゴリを使用して混同行列を計算し、上で定義した Lot_confusion_matrix() 関数を使用して混同行列を表す必要があります。
4. 概要
Python 言語は、データ サイエンティストや研究者がディープ ラーニングや人工知能のデータ分析をより迅速に実行できるようにする、多数の視覚化およびデータ分析ライブラリを提供します。この記事では、混同行列とそのアプリケーション、Python で混同行列を計算する方法、および matplotlib ライブラリを使用して混同行列のグラフィックを生成する方法を紹介します。混同行列技術は、ディープラーニングや人工知能の分野で重要な応用分野があるため、混同行列技術を習得することが非常に必要です。
以上がPython の混同行列のトリックの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Pythonは、データサイエンス、Web開発、自動化タスクに適していますが、Cはシステムプログラミング、ゲーム開発、組み込みシステムに適しています。 Pythonは、そのシンプルさと強力なエコシステムで知られていますが、Cは高性能および基礎となる制御機能で知られています。

2時間以内にPythonの基本的なプログラミングの概念とスキルを学ぶことができます。 1.変数とデータ型、2。マスターコントロールフロー(条件付きステートメントとループ)、3。機能の定義と使用を理解する4。

Pythonは、Web開発、データサイエンス、機械学習、自動化、スクリプトの分野で広く使用されています。 1)Web開発では、DjangoおよびFlask Frameworksが開発プロセスを簡素化します。 2)データサイエンスと機械学習の分野では、Numpy、Pandas、Scikit-Learn、Tensorflowライブラリが強力なサポートを提供します。 3)自動化とスクリプトの観点から、Pythonは自動テストやシステム管理などのタスクに適しています。

2時間以内にPythonの基本を学ぶことができます。 1。変数とデータ型を学習します。2。ステートメントやループの場合などのマスター制御構造、3。関数の定義と使用を理解します。これらは、簡単なPythonプログラムの作成を開始するのに役立ちます。

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

Python 3.6のピクルスファイルのロードレポートエラー:modulenotFounderror:nomodulenamed ...

風光明媚なスポットコメント分析におけるJieba Wordセグメンテーションの問題を解決する方法は?風光明媚なスポットコメントと分析を行っているとき、私たちはしばしばJieba Wordセグメンテーションツールを使用してテキストを処理します...


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 中国語版
中国語版、とても使いやすい

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません
