2. Multivariate Analyse in Python 8-1. K Nachbarschaftsmethode (Scikit-Learn)

2_8_1_01.PNG

** Kann auch für die Regression verwendet werden, aber hier werden wir einen Klassifizierungsfall durchführen. ** ** **

⑴ Bibliothek importieren

import numpy as np
import pandas as pd

from sklearn import datasets
# sklearn.Nachbarmodul k-NN-Methode
from sklearn.neighbors import KNeighborsClassifier
#Dienstprogramm sklearn data split
from sklearn.model_selection import train_test_split

import matplotlib.pyplot as plt
#Methode zum Generieren einer Farbkarte
from matplotlib.colors import ListedColormap

#Japanisches Anzeigemodul von matplotlib
!pip install japanize-matplotlib
import japanize_matplotlib

Bereiten Sie die Daten vor

Variablennamen Bedeutung Hinweis Datentyp
0 species Art Setosa=0, Versicolour=1, Virginica=2 int64
1 sepal length Die Länge des Stückes Kontinuierliche Menge(cm) float64
2 sepal width Breite des Stückes Kontinuierliche Menge(cm) float64
3 petal length Blütenblattlänge Kontinuierliche Menge(cm) float64
4 petal width Blütenblattbreite Kontinuierliche Menge(cm) float64

⑵ Datenerfassung

iris = datasets.load_iris()
#Erklärende Variable (Merkmalsbetrag)
print("Etikette:\n", iris.feature_names)
print("gestalten:\n", iris.data.shape)
print("Erste 10 Zeilen:\n", iris.data[0:10, :]) 

#Zielvariable (Typ)
print("Etikette:\n", iris.target_names)
print("gestalten:\n", iris.target.shape)
print("Vollanzeige:\n", iris.target)

2_8_1_02.PNG

⑶ Datenaufteilung

X_train, X_test, y_train, y_test = train_test_split(
    iris.data, 
    iris.target,
    stratify = iris.target, #Geschichtete Stichprobe
    random_state = 0)
print("gestalten:", y_train.shape)

#Holen Sie sich die Anzahl der eindeutigen Elemente
np.unique(y_train, return_counts=True)

2_8_1_03.PNG

Bestimmen Sie die Anzahl von k

⑷ Führen Sie k-NN aus, während Sie den Parameter k ändern

#Variable, die die Genauigkeitsrate speichert
training_accuracy = []
test_accuracy = []

#k beim Ändern von k-Führen Sie NN aus und erhalten Sie die richtige Antwortrate
for k in range(3,21):
    #Übergeben Sie k, um eine Instanz zu erstellen, die Daten anzupassen und ein Modell zu generieren
    kNN = KNeighborsClassifier(n_neighbors = k)
    kNN.fit(X_train, y_train)
    #Erhalten Sie die richtige Antwortrate mit Punktzahl und speichern Sie sie nacheinander
    training_accuracy.append(kNN.score(X_train, y_train))
    test_accuracy.append(kNN.score(X_test, y_test))

#Konvertieren Sie die Genauigkeitsrate in ein Numpy-Array
training_accuracy = np.array(training_accuracy)
test_accuracy = np.array(test_accuracy)

⑸ Wählen Sie den optimalen k-Parameter

#Änderungen der Genauigkeitsrate für Training und Test
plt.figure(figsize=(6, 4))

plt.plot(range(3,21), training_accuracy, label='Ausbildung')
plt.plot(range(3,21), test_accuracy, label='Prüfung')

plt.xticks(np.arange(2, 21, 1)) #x-Achsenskala
plt.xlabel('k Nummer')
plt.ylabel('Richtige Antwortrate')
plt.title('Übergang der richtigen Antwortrate')

plt.grid()
plt.legend()

#Übergang der Differenz in der richtigen Antwortrate
plt.figure(figsize=(6, 4))

difference = np.abs(training_accuracy - test_accuracy) #Berechnen Sie die Differenz
plt.plot(range(3,21), difference, label='Unterschied')

plt.xticks(np.arange(2, 21, 1)) #x-Achsenskala
plt.xlabel('k Nummer')
plt.ylabel('Unterschied(train - test)')
plt.title('Übergang der Differenz in der richtigen Antwortrate')

plt.grid()
plt.legend()

plt.show()

2_8_1_04.PNG

Führen Sie k-NN aus und visualisieren Sie es

⑹ Führen Sie k-NN mit dem optimalen k-Parameter erneut aus

#Geben Sie die Anzahl von k an
k = 15

#Stellen Sie die erklärende Variable X und die Zielvariable y ein
X = iris.data[:, :2]
y = iris.target

#Erstellen Sie eine Instanz, passen Sie die Daten an und generieren Sie ein Modell
model = KNeighborsClassifier(n_neighbors=k)
model.fit(X, y)

⑺ Auf Konturdiagramm zeichnen (Isoliniendiagramm)

#Geben Sie den Netzabstand an
h = 0.02

#Erstellen Sie eine Farbkarte
cmap_surface = ListedColormap(['darkseagreen', 'mediumpurple', 'gold']) #Für Oberflächendiagramm
cmap_dot = ListedColormap(['darkgreen', 'darkslateblue', 'olive']) #Zum Streuzeichnen

# x,Ermitteln Sie die Minimal- und Maximalwerte der y-Achse
x_min, x_max = X[:, 0].min() - 1, X[:, 0].max() + 1
y_min, y_max = X[:, 1].min() - 1, X[:, 1].max() + 1
#Generieren Sie Rasterspalten in festgelegten Netzintervallen
xx, yy = np.meshgrid(np.arange(x_min, x_max, h),
                     np.arange(y_min, y_max, h))

#Vorhersage durch Übergabe der Gittersequenz an das Modell
Z = model.predict(np.c_[xx.ravel(), yy.ravel()])
Z = Z.reshape(xx.shape) #Formkonvertierung

2_8_1_06.PNG

plt.figure(figsize=(6,5))

#Diagramm isolieren
plt.pcolormesh(xx, yy, Z, cmap=cmap_surface)
#Streudiagramm
plt.scatter(X[:, 0], X[:, 1], c=y, cmap=cmap_dot, s=30)

plt.xlim(xx.min(), xx.max())
plt.ylim(yy.min(), yy.max())
plt.xlabel('sepal length')
plt.ylabel('sepal width')

plt.show()

2_8_1_05.PNG

Nachwort

Recommended Posts

2. Multivariate Analyse in Python 8-1. K Nachbarschaftsmethode (Scikit-Learn)
2. Multivariate Analyse in Python 8-3. K Nachbarschaftsmethode [Schnittstellenüberprüfung]
2. Multivariate Analyse in Python 8-2. K Nachbarschaftsmethode [Gewichtungsmethode] [Rückgabemodell]
2. Multivariate Analyse in Python 1-1. Einfache Regressionsanalyse (Scikit-Learn)
2. Multivariate Analyse in Python 7-1. Entscheidungsbaum (Scikit-Learn)
2. Multivariate Analyse in Python 2-1. Multiple Regressionsanalyse (Scikit-Learn)
2. Multivariate Analyse in Python 3-1. Hauptkomponentenanalyse (Scikit-Learn)
2. Multivariate Analyse in Python 6-2. Ridge-Regression / Lasso-Regression (Scikit-Learn) [Ridge-Regression vs. Lasso-Regression]
2. Multivariate Analyse in Python 6-1. Ridge-Regression / Lasso-Regression (Scikit-Learn) [multiple Regression vs. Ridge-Regression]
2. Multivariate Analyse in Python 3-2. Hauptkomponentenanalyse (Algorithmus)
2. Multivariate Analyse in Python 7-3. Entscheidungsbaum [Rückgabebaum]
2. Multivariate Analyse in Python 1-2. Einfache Regressionsanalyse (Algorithmus)
2. Multivariate Analyse in Python 6-3. Ridge-Regression / Lasso-Regression (Scikit-Learn) [Funktionsweise der Regularisierung]
2. Multivariate Analyse in Python 5-3. Logistische Regressionsanalyse (Statistikmodelle)
[Python] [scikit-learn] k-Einführung in das Memo der Methode des nächsten Nachbarn
2. Multivariate Analyse in Python 7-2. Entscheidungsbaum [Unterschied in den Teilungskriterien]
2. Multivariate Analyse in Python 2-3. Multiple Regressionsanalyse [COVID-19-Infektionsrate]
Implementierte k-Neighborhood-Methode in Python von Scikit Learn
Simplex-Methode (Einzelmethode) in Python
Private Methode in Python
Assoziationsanalyse in Python
Regressionsanalyse mit Python
Eine einfache Python-Implementierung der k-Neighborhood-Methode (k-NN)
K Nachbarschaftsmethode (Mehrklassenklassifikation)
Axialsymmetrische Spannungsanalyse mit Python
Einfache Regressionsanalyse mit Python
[Maschinelles Lernen] Schreiben Sie die Methode des nächsten Nachbarn in Python selbst und erkennen Sie handgeschriebene Zahlen.
Das Unterdrücken von Methodenüberschreibungen in Python
[Python] PCA-Scratch im Beispiel "Einführung in die multivariate Analysemethode"
Gehirnwellenanalyse mit Python: Python MNE-Tutorial
Erste einfache Regressionsanalyse in Python
Implementierte Methode zur Weitergabe von Etiketten in Python
Simulieren Sie die Monte-Carlo-Methode in Python
Scikit-learn kann nicht in Python installiert werden
Hash-Methode (Open-Address-Methode) in Python
Planare Skelettanalyse in Python (2) Hotfix
Lineare Regression in Python (Statmodelle, Scikit-Learn, PyMC3)
Methode zum Erstellen einer Python-Umgebung in Xcode 6
Elektronenmikroskopsimulation in Python: Mehrschichtmethode (1)
Elektronenmikroskopsimulation in Python: Mehrschichtmethode (2)
Restanalyse in Python (Ergänzung: Cochrane-Regeln)
Ausrichtungsalgorithmus durch Einfügemethode in Python