** Kann auch für die Regression verwendet werden, aber hier werden wir einen Klassifizierungsfall durchführen. ** ** **
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
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 |
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)
X_train, X_test, y_train, y_test = train_test_split(
iris.data,
iris.target,
stratify = iris.target, #Geschichtete Stichprobe
random_state = 0)
stratify = iris.target
gibt ** geschichtete Stichproben ** nach Typ (iris.target) an. Die Standardeinstellung ist die Zufallsstichprobe. Daher werden wir sie hier so aufteilen, dass drei Arten von Zusammensetzungsverhältnissen für Training und Test beibehalten werden.print("gestalten:", y_train.shape)
#Holen Sie sich die Anzahl der eindeutigen Elemente
np.unique(y_train, return_counts=True)
#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)
#Ä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()
#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)
#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
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()
pcolormesh ()
von matplotlib erzeugt ein Farbdiagramm basierend auf einem unregelmäßigen rechteckigen Raster.