Inhaltsverzeichnis
Für Klassifizierungsaufgaben:
Für Regressionsaufgaben:
Beispiel: Klassifizierung
Beispiel: Regression
3.. Kreuzvalidierung für eine robuste Bewertung
Visualisieren Sie die Leistung (optional, aber hilfreich)
Heim Backend-Entwicklung Python-Tutorial Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

Aug 16, 2025 am 01:22 AM

Auswählen geeignete Bewertungsindikatoren: Die Klassifizierungsaufgabe verwendet Genauigkeit, Genauigkeit, Rückruf, F1-Score, ROC-AuC und Verwirrungsmatrix, und die Regressionsaufgabe verwendet Mae, MSE, RMSE und R². 2. Verwenden Sie Scikit-Learn, um die Indikatoren zu berechnen, und implementieren Sie die Bewertung des Klassifizierungs- und Regressionsmodells durch Funktionen im sklearn.metrics-Modul; 3.. Verwenden Sie die Quervalidierung (wie Cross_val_Score), um eine robustere Leistungsbewertung durchzuführen, um Abweichungen zu vermeiden, die durch einzelne Teilung verursacht werden. 4. visualisieren Sie optional die Modellleistung durch ROC -Kurven und Verwirrungsmatrix -Thermogramme; Der Schlüssel zur Bewertung des Modells besteht darin, geeignete Indikatoren basierend auf dem Problem auszuwählen und Kreuzvalidierung und visuelle umfassende Analyse zu kombinieren, um den Modelleffekt genau zu beurteilen und falsche Schlussfolgerungen zu vermeiden, die durch den Missbrauch von Indikatoren verursacht werden.

Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

Bei der Bewertung der Leistung eines maschinellen Lernens in Python beinhaltet die Auswahl der richtigen Metriken und Tools basierend auf der Art des Problems-der Klassifizierung, der Regression oder anderer-und der Verwendung von Bibliotheken wie scikit-learn um sie zu berechnen. Hier erfahren Sie, wie man es effektiv macht.

Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

1. Wählen Sie die richtigen Bewertungsmetriken aus

Der erste Schritt ist die Auswahl geeigneter Metriken basierend auf Ihrer Aufgabe:

Für Klassifizierungsaufgaben:

  • Genauigkeit : Anteil der korrekten Vorhersagen. Gut, wenn der Unterricht ausgeglichen ist.
  • Präzision, Rückruf, F1-Score : Informativer für unausgeglichene Datensätze.
    • Präzision : Wie viele sind von allen vorhergesagten positiven positiven positiven Positiven?
    • Rückruf (Empfindlichkeit) : Wie viele wurden von allen tatsächlichen positiven Positiven richtig vorhergesagt?
    • F1-Score : Harmonische Mittel zur Präzision und Rückruf.
  • ROC-AuC : misst, wie gut ein Modell Vorhersagen einräumt; Nützlich für die binäre Klassifizierung mit Wahrscheinlichkeitsausgaben.
  • Verwirrungsmatrix : zeigt wahre Positive, falsch positive Aspekte usw. für eine detaillierte Analyse.

Für Regressionsaufgaben:

  • Mittlerer absoluter Fehler (MAE) : Durchschnittliche absolute Differenz zwischen vorhergesagten und tatsächlichen Werten.
  • Mittlerer quadratischer Fehler (MSE) : Bestrafte größere Fehler.
  • Root Mean Squared Fehler (RMSE) : MSE auf der ursprünglichen Skala.
  • R² (R-Quadrat) : Anteil der durch das Modell erklärten Variation (näher an 1 ist besser).

2. Verwenden Sie Scikit-Learn, um Metriken zu berechnen

Sobald Ihr Modell trainiert und Vorhersagen getätigt werden, verwenden Sie sklearn.metrics :

Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

Beispiel: Klassifizierung

 Aus sklearn.model_selection importieren train_test_split
aus sklearn.ensemble import randomforestclassifierer
von sklearn.metrics importieren Sie Accuracy_Score, precision_recall_fscore_support, ROC_AUC_SCORE, Confusion_Matrix
von sklearn.datasets import make_classification

# Beispieldaten generieren
X, y = make_classification (n_samples = 1000, n_features = 10, n_classeses = 2, random_state = 42)
X_train, x_test, y_train, y_test = train_test_split (x, y, test_size = 0.3, random_state = 42)

# Zugmodell
Modell = RandomforestClassifier (Random_State = 42)
model.fit (x_train, y_train)
y_pred = model.predict (x_test)
y_prob = model.Predict_Proba (x_test) [:, 1] # Wahrscheinlichkeit für die positive Klasse

# Auswerten
accuracy = accuracy_score (y_test, y_pred)
Präzision, Rückruf, F1, _ = precision_recall_fscore_support (y_test, y_pred, durchschnitt = 'binär')
AUC = ROC_AUC_SCORE (y_test, y_prob)
cm = confusion_matrix (y_test, y_pred)

print (f "Genauigkeit: {Genauigkeit: .3f}")
print (f "precision: {precision: .3f}, rechnen Sie: {rechnen: .3f}, f1: {f1: .3f}")
print (f "roc-auc: {auc: .3f}")
print ("Verwirrungsmatrix:")
Druck (cm)

Beispiel: Regression

 von sklearn.ensemble import randomforestregressor
von sklearn.metrics import Mean_absolute_error, messine_squared_error, r2_score
von sklearn.datasets import make_regression

# Beispieldaten generieren
X, y = make_regression (n_samples = 1000, n_features = 5, rauschen = 0,1, random_state = 42)
X_train, x_test, y_train, y_test = train_test_split (x, y, test_size = 0.3, random_state = 42)

# Zugmodell
reg_model = randomforestregressor (random_state = 42)
reg_model.fit (x_train, y_train)
y_pred = reg_model.predict (x_test)

# Auswerten
mae = Mean_absolute_error (y_test, y_pred)
MSE = Mean_Squared_error (y_test, y_pred)
RMSE = MSE ** 0.5
r2 = r2_score (y_test, y_pred)

print (f "mae: {mae: .3f}")
print (f "mse: {mse: .3f}")
print (f "rmse: {rmse: .3f}")
print (f "r²: {r2: .3f}")

3.. Kreuzvalidierung für eine robuste Bewertung

Verwenden Sie anstelle eines einzelnen Zugtests eine Kreuzvalidierung, um eine zuverlässigere Schätzung zu erhalten:

 von sklearn.model_selection import cross_val_score

# Zur Klassifizierung
cv_accuracy = cross_val_score (Modell, x, y, cv = 5, Scoring = 'Genauigkeit')
print (f "CV-Genauigkeit: {cv_accuracy.mean () :. 3f} ( /- {cv_accuracy.std () * 2: .3f})")

# Für die Regression
cv_r2 = cross_val_score (reg_model, x, y, cv = 5, Scoring = 'R2')
print (f "cv r²: {cv_r2.mean () :. 3f} ( /- {cv_r2.std () * 2: .3f})")

Häufige Bewertungsoptionen: 'accuracy' , 'precision' , 'recall' , 'f1' , 'roc_auc' , 'r2' , 'neg_mean_squared_error' , usw.

Wie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?

Visualisieren Sie die Leistung (optional, aber hilfreich)

  • ROC -Kurve :
    aus sklearn.metrics importieren Sie ROC_CURVE
    matplotlib.pyplot als pLT importieren

fpr, tpr, _ = roc_curve(y_test, y_prob) plt.plot(fpr, tpr, label=f"ROC Curve (AUC = {auc:.2f})") plt.plot([0, 1], [0, 1], 'k--') plt.xlabel("False Positive Rate") plt.ylabel("True Positive Rate") Plt.title ("ROC -Kurve") plt.Legend () plt.show ()

- ** Verwirrungsmatrix Heatmap **:
`` `Python
Importieren Sie Seeborn als SNS
sns.heatmap (cm, Annot = true, fmt = 'd', cmap = 'Blues')
PLT.TITLE ("Verwirrungsmatrix")
Plt.ylabel ("tatsächlich")
pt.xlabel ("vorhergesagt")
Plt.Show ()

Grundsätzlich ist die Bewertung eines Modells in Python auf:

  • Auswahl der richtigen Metrik für Ihr Problem,
  • Verwenden von scikit-learn -Funktionen, um es zu berechnen,
  • Validierung mit Kreuzvalidierung,
  • Und optional visualisierende Ergebnisse.

Es ist nicht kompliziert, aber die Auswahl der falschen Metrik (z.

Das obige ist der detaillierte Inhalt vonWie bewerten Sie die Leistung eines maschinellen Lernmodells in Python?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

PHP-Tutorial
1587
276
Python Run Shell -Befehlsbeispiel Python Run Shell -Befehlsbeispiel Jul 26, 2025 am 07:50 AM

Verwenden Sie Subprozess.run (), um die Befehle von Shell sicher auszuführen und die Ausgabe zu erfassen. Es wird empfohlen, Parameter in Listen zu übergeben, um Einspritzrisiken zu vermeiden. 2. Wenn die Shell -Eigenschaften erforderlich sind, können Sie Shell = True einstellen, aber achten Sie auf die Befehlsinjektion. 3. verwenden subprocess.popen, um die Echtzeit-Ausgangsverarbeitung zu realisieren. 4. Setzen Sie check = true, um Ausnahmen zu werfen, wenn der Befehl fehlschlägt. 5. Sie können direkt Ketten anrufen, um die Ausgabe in einem einfachen Szenario zu erhalten. Sie sollten Subprozess vorrangig machen. Die obigen Methoden überschreiben die Kernverwendung der Ausführung von Shell -Befehlen in Python.

Python Seeborn JointPlot Beispiel Python Seeborn JointPlot Beispiel Jul 26, 2025 am 08:11 AM

Verwenden Sie die Jointplot von Seeborn, um die Beziehung und Verteilung zwischen zwei Variablen schnell zu visualisieren. 2. Das grundlegende Streudiagramm wird durch sns.jointplot (data = tips, x = "total_bill", y = "tip", sort = "scatter") implementiert, das Zentrum ist ein Streudiagramm und das Histogramm wird auf der oberen und unteren und rechten Seite angezeigt. 3. Fügen Sie Regressionslinien und Dichteinformationen zu einer Art "Reg" hinzu und kombinieren Sie Marginal_KWS, um den Edge -Plot -Stil festzulegen. 4. Wenn das Datenvolumen groß ist, wird empfohlen, "Hex" zu verwenden,

Python -Liste zum String Conversion Beispiel Python -Liste zum String Conversion Beispiel Jul 26, 2025 am 08:00 AM

String -Listen können mit der join () -Methode wie '' .Join (Words) zusammengeführt werden, um "helloWorldfrompython" zu erhalten; 2. Die Zahlenlisten müssen vor dem Beitritt in Zeichenfolgen mit Karte (STR, Zahlen) oder [STR (x) ForxInnumbers] konvertiert werden. 3. Jede Typliste kann direkt in Zeichenfolgen mit Klammern und Zitaten umgewandelt werden, die zum Debuggen geeignet sind. 4. Benutzerdefinierte Formate können durch Generatorausdrücke in Kombination mit Join () implementiert werden, wie z.

Python verbinden sich mit SQL Server PyoDBC -Beispiel Python verbinden sich mit SQL Server PyoDBC -Beispiel Jul 30, 2025 am 02:53 AM

Installieren Sie PYODBC: Verwenden Sie den Befehl pipinstallpyoDBC, um die Bibliothek zu installieren. 2. SQLServer verbinden: Verwenden Sie die Verbindungszeichenfolge, die Treiber, Server, Datenbank, UID/PWD oder Trusted_Connection über die Methode Pyodbc.Connect () und die SQL -Authentifizierung bzw. der Windows -Authentifizierung unterstützen; 3. Überprüfen Sie den installierten Treiber: Führen Sie Pyodbc.Drivers () aus und filtern Sie den Treibernamen mit 'SQLServer', um sicherzustellen, dass der richtige Treiberame wie 'ODBCDRIVER17 für SQLServer' verwendet wird. 4. Schlüsselparameter der Verbindungszeichenfolge

Python httpx Async Client Beispiel Python httpx Async Client Beispiel Jul 29, 2025 am 01:08 AM

Verwenden Sie httpx.asyncclient, um asynchrone HTTP -Anforderungen effizient zu initiieren. 1. Basic-Get-Anfragen verwalten Clients über Asyncwith und verwenden Sie AwaitClient.get, um nicht blockierende Anforderungen zu initiieren. 2. kombiniert asyncio.gather, sich mit asyncio zu kombinieren. Gather kann die Leistung erheblich verbessern, und die Gesamtzeit entspricht der langsamsten Anfrage. 3.. Unterstützen Sie benutzerdefinierte Header, Authentifizierung, Base_url und Zeitüberschreitungseinstellungen; 4. kann Postanfragen senden und JSON -Daten tragen; 5. Achten Sie darauf, dass das Mischen von synchronem asynchronem Code vermieden wird. Der Proxy-Support muss auf die Back-End-Kompatibilität achten, die für Crawlers oder API-Aggregation und andere Szenarien geeignet ist.

Optimierung von Python für Speichervorgänge Optimierung von Python für Speichervorgänge Jul 28, 2025 am 03:22 AM

PythoncanbeoptimizedFormemory-BoundoperationsByreducingoverheadThroughGeneratoren, effiziente Datastrukturen und ManagingObjectLifetimes.First, UseGeneratorsinSteadofListStoprocesslargedatasetasetasematatime, Vermeidung von loloadingeNthertomemory.Secondatasetasetematatime, Choos

SQLALCHEMY 2.0 Abschreibungswarnung und Verbindungs Problem Lösung Leitfaden SQLALCHEMY 2.0 Abschreibungswarnung und Verbindungs Problem Lösung Leitfaden Aug 05, 2025 pm 07:57 PM

In diesem Artikel soll die Anfänger der SQLALCHEMY die Warnung "entfernte20Warning" beheben, die bei der Verwendung von create_engine und dem nachfolgenden "ResourceClostener" -Knotenschließfehler auftreten. Der Artikel erläutert die Ursache dieser Warnung im Detail und liefert spezifische Schritte und Codebeispiele, um die Warn- und Behebung von Verbindungsproblemen zu beseitigen, um sicherzustellen, dass Sie die Datenbank reibungslos abfragen und bedienen können.

Python Shutil Rmtree Beispiel Python Shutil Rmtree Beispiel Aug 01, 2025 am 05:47 AM

Shutil.rmtree () ist eine Funktion in Python, die den gesamten Verzeichnisbaum rekursiv löscht. Es kann bestimmte Ordner und alle Inhalte löschen. 1. Basisnutzung: Verwenden Sie Shutil.rmtree (Pfad), um das Verzeichnis zu löschen, und Sie müssen FilenotFoundError, Erlaubnissekror und andere Ausnahmen verarbeiten. 2. Praktische Anwendung: Sie können Ordner, die Unterverzeichnisse und Dateien enthalten, in einem Klick löschen, z. B. temporäre Daten oder zwischengespeicherte Verzeichnisse. 3. ANMERKUNGEN: Der Löschvorgang wird nicht wiederhergestellt; FilenotFoundError wird geworfen, wenn der Weg nicht existiert. Es kann aufgrund von Berechtigungen oder Einstellungen fehlschlagen. 4. Optionale Parameter: Fehler können von ignore_errors = true ignoriert werden

See all articles