Natural Language Toolkit - Textklassifizierung

Was ist Textklassifizierung?

Die Textklassifizierung ist, wie der Name schon sagt, die Möglichkeit, Textstücke oder Dokumente zu kategorisieren. Aber hier stellt sich die Frage, warum wir Textklassifikatoren verwenden müssen. Sobald die Wortverwendung in einem Dokument oder Textstück untersucht wurde, können die Klassifizierer entscheiden, welche Klassenbezeichnung ihr zugewiesen werden soll.

Binärer Klassifikator

Wie der Name schon sagt, entscheidet der binäre Klassifikator zwischen zwei Bezeichnungen. Zum Beispiel positiv oder negativ. In diesem Fall kann der Text oder das Dokument entweder das eine oder das andere Etikett sein, aber nicht beide.

Multi-Label-Klassifikator

Im Gegensatz zum binären Klassifikator kann der Multi-Label-Klassifikator einem Text oder Dokument eine oder mehrere Beschriftungen zuweisen.

Labeled Vs Unlabeled Feature Set

Eine Schlüsselwertzuordnung von Feature-Namen zu Feature-Werten wird als Feature-Set bezeichnet. Beschriftete Feature-Sets oder Trainingsdaten sind für das Klassifizierungstraining sehr wichtig, damit sie später unbeschriftete Feature-Sets klassifizieren können.

Beschrifteter Funktionsumfang Unbeschrifteter Funktionsumfang
Es ist ein Tupel, das aussieht wie (feat, label). Es ist eine Leistung für sich.
Es ist eine Instanz mit einer bekannten Klassenbezeichnung. Ohne zugehöriges Label können wir es eine Instanz nennen.
Wird zum Trainieren eines Klassifizierungsalgorithmus verwendet. Nach dem Training kann der Klassifizierungsalgorithmus einen unbeschrifteten Funktionsumfang klassifizieren.

Extraktion von Textfunktionen

Wie der Name schon sagt, wird beim Extrahieren von Textmerkmalen eine Liste von Wörtern in einen Funktionssatz umgewandelt, der von einem Klassifizierer verwendet werden kann. Wir müssen unseren Text in verwandeln‘dict’ Stil-Feature-Sets, da das Natural Language Tool Kit (NLTK) dies erwartet ‘dict’ Stil-Feature-Sets.

Modell Bag of Words (BoW)

BoW, eines der einfachsten Modelle in NLP, wird verwendet, um die Features aus Textstücken oder Dokumenten zu extrahieren, damit sie bei der Modellierung verwendet werden können, z. B. in ML-Algorithmen. Grundsätzlich wird aus allen Wörtern einer Instanz ein Wortpräsenz-Feature-Set erstellt. Das Konzept hinter dieser Methode ist, dass es nicht darum geht, wie oft ein Wort vorkommt oder in welcher Reihenfolge die Wörter stehen, sondern nur darum, ob das Wort in einer Liste von Wörtern vorhanden ist oder nicht.

Beispiel

In diesem Beispiel definieren wir eine Funktion namens bow () -

def bow(words):
   return dict([(word, True) for word in words])

Rufen wir jetzt an bow()Funktion auf Wörter. Wir haben diese Funktionen in einer Datei namens bagwords.py gespeichert.

from bagwords import bow
bow(['we', 'are', 'using', 'tutorialspoint'])

Ausgabe

{'we': True, 'are': True, 'using': True, 'tutorialspoint': True}

Trainingsklassifikatoren

In den vorherigen Abschnitten haben wir gelernt, wie Features aus dem Text extrahiert werden. Jetzt können wir einen Klassifikator trainieren. Der erste und einfachste Klassifikator istNaiveBayesClassifier Klasse.

Naiver Bayes-Klassifikator

Um die Wahrscheinlichkeit vorherzusagen, dass ein bestimmter Feature-Set zu einem bestimmten Label gehört, wird der Bayes-Satz verwendet. Die Formel des Bayes-Theorems lautet wie folgt.

$$ P (A | B) = \ frac {P (B | A) P (A)} {P (B)} $$

Hier,

P(A|B) - Es wird auch die hintere Wahrscheinlichkeit genannt, dh die Wahrscheinlichkeit, dass das erste Ereignis, dh A, auftritt, wenn das zweite Ereignis, dh B, auftritt.

P(B|A) - Es ist die Wahrscheinlichkeit, dass das zweite Ereignis, dh B, nach dem ersten Ereignis, dh A, auftritt.

P(A), P(B) - Es wird auch als vorherige Wahrscheinlichkeit bezeichnet, dh die Wahrscheinlichkeit, dass das erste Ereignis, dh A, oder das zweite Ereignis, dh B, eintritt.

Um den Naïve Bayes-Klassifikator zu trainieren, verwenden wir den movie_reviewsKorpus von NLTK. Dieser Korpus hat zwei Textkategorien, nämlich:pos und neg. Diese Kategorien machen einen darauf trainierten Klassifikator zu einem binären Klassifikator. Jede Datei im Korpus besteht aus zwei Dateien, eine positive Filmkritik und eine negative Filmkritik. In unserem Beispiel verwenden wir jede Datei als einzelne Instanz, um den Klassifikator zu trainieren und zu testen.

Beispiel

Für den Trainingsklassifikator benötigen wir eine Liste mit beschrifteten Funktionssätzen in der Form [(featureset, label)]. Hier dasfeatureset Variable ist a dict und label ist das bekannte Klassenlabel für das featureset. Wir werden eine Funktion mit dem Namen erstellenlabel_corpus() welches einen Korpus namens nehmen wird movie_reviewsund auch eine Funktion namens feature_detector, die standardmäßig ist bag of words. Es wird eine Zuordnung des Formulars {label: [featureset]} erstellt und zurückgegeben. Danach verwenden wir diese Zuordnung, um eine Liste der gekennzeichneten Trainingsinstanzen und Testinstanzen zu erstellen.

import collections

def label_corpus(corp, feature_detector=bow):
   label_feats = collections.defaultdict(list)
   for label in corp.categories():
      for fileid in corp.fileids(categories=[label]):
         feats = feature_detector(corp.words(fileids=[fileid]))
         label_feats[label].append(feats)
   return label_feats

Mit Hilfe der obigen Funktion erhalten wir eine Zuordnung {label:fetaureset}. Jetzt definieren wir eine weitere Funktion mit dem Namensplit Dies erfordert eine Zuordnung, die von zurückgegeben wird label_corpus() Funktion und teilt jede Liste von Funktionssätzen in gekennzeichnete Trainings- und Testinstanzen auf.

def split(lfeats, split=0.75):
   train_feats = []
   test_feats = []
   for label, feats in lfeats.items():
      cutoff = int(len(feats) * split)
      train_feats.extend([(feat, label) for feat in feats[:cutoff]])
      test_feats.extend([(feat, label) for feat in feats[cutoff:]])
   return train_feats, test_feats

Lassen Sie uns nun diese Funktionen auf unserem Korpus verwenden, dh movie_reviews -

from nltk.corpus import movie_reviews
from featx import label_feats_from_corpus, split_label_feats
movie_reviews.categories()

Ausgabe

['neg', 'pos']

Beispiel

lfeats = label_feats_from_corpus(movie_reviews)
lfeats.keys()

Ausgabe

dict_keys(['neg', 'pos'])

Beispiel

train_feats, test_feats = split_label_feats(lfeats, split = 0.75)
len(train_feats)

Ausgabe

1500

Beispiel

len(test_feats)

Ausgabe

500

Wir haben das in gesehen movie_reviewsKorpus, es gibt 1000 Pos-Dateien und 1000 Neg-Dateien. Wir haben außerdem 1500 gekennzeichnete Trainingsinstanzen und 500 gekennzeichnete Testinstanzen.

Jetzt lass uns trainieren NaïveBayesClassifier mit seiner train() Klassenmethode -

from nltk.classify import NaiveBayesClassifier
NBC = NaiveBayesClassifier.train(train_feats)
NBC.labels()

Ausgabe

['neg', 'pos']

Entscheidungsbaum-Klassifikator

Ein weiterer wichtiger Klassifikator ist der Entscheidungsbaumklassifikator. Hier, um es zu trainierenDecisionTreeClassifierKlasse erstellt eine Baumstruktur. In dieser Baumstruktur entspricht jeder Knoten einem Merkmalsnamen und die Zweige entsprechen den Merkmalswerten. Und die Äste hinunter gelangen wir zu den Blättern des Baumes, dh zu den Klassifizierungsetiketten.

Um den Entscheidungsbaumklassifikator zu trainieren, verwenden wir dieselben Trainings- und Testfunktionen, d. H. train_feats und test_feats, Variablen, aus denen wir erstellt haben movie_reviews Korpus.

Beispiel

Um diesen Klassifikator zu trainieren, werden wir anrufen DecisionTreeClassifier.train() Klassenmethode wie folgt -

from nltk.classify import DecisionTreeClassifier
decisiont_classifier = DecisionTreeClassifier.train(
   train_feats, binary = True, entropy_cutoff = 0.8, 
   depth_cutoff = 5, support_cutoff = 30
)
accuracy(decisiont_classifier, test_feats)

Ausgabe

0.725

Maximaler Entropieklassifikator

Ein weiterer wichtiger Klassifikator ist MaxentClassifier das ist auch bekannt als conditional exponential classifier oder logistic regression classifier. Hier, um es zu trainieren, dieMaxentClassifier Die Klasse konvertiert beschriftete Feature-Sets mithilfe der Codierung in einen Vektor.

Um den Entscheidungsbaumklassifikator zu trainieren, verwenden wir dieselben Trainings- und Testfunktionen, d. H. train_featsund test_feats, Variablen, aus denen wir erstellt haben movie_reviews Korpus.

Beispiel

Um diesen Klassifikator zu trainieren, werden wir anrufen MaxentClassifier.train() Klassenmethode wie folgt -

from nltk.classify import MaxentClassifier
maxent_classifier = MaxentClassifier
.train(train_feats,algorithm = 'gis', trace = 0, max_iter = 10, min_lldelta = 0.5)
accuracy(maxent_classifier, test_feats)

Ausgabe

0.786

Scikit-Learn-Klassifikator

Eine der besten Bibliotheken für maschinelles Lernen (ML) ist Scikit-learn. Es enthält tatsächlich alle Arten von ML-Algorithmen für verschiedene Zwecke, aber alle haben das gleiche Anpassungsmuster wie folgt:

  • Anpassen des Modells an die Daten
  • Und verwenden Sie dieses Modell, um Vorhersagen zu treffen

Anstatt direkt auf Scikit-Lernmodelle zuzugreifen, werden wir hier NLTKs verwenden SklearnClassifierKlasse. Diese Klasse ist eine Wrapper-Klasse um ein Scikit-Lernmodell, um es an die Classifier-Schnittstelle von NLTK anzupassen.

Wir werden die folgenden Schritte ausführen, um a zu trainieren SklearnClassifier Klasse -

Step 1 - Zuerst erstellen wir Trainingsfunktionen wie in früheren Rezepten.

Step 2 - Wählen Sie nun einen Scikit-Lernalgorithmus aus und importieren Sie ihn.

Step 3 - Als nächstes müssen wir eine konstruieren SklearnClassifier Klasse mit dem gewählten Algorithmus.

Step 4 - Zuletzt werden wir trainieren SklearnClassifier Klasse mit unseren Trainingsfunktionen.

Lassen Sie uns diese Schritte im folgenden Python-Rezept implementieren -

from nltk.classify.scikitlearn import SklearnClassifier
from sklearn.naive_bayes import MultinomialNB
sklearn_classifier = SklearnClassifier(MultinomialNB())
sklearn_classifier.train(train_feats)
<SklearnClassifier(MultinomialNB(alpha = 1.0,class_prior = None,fit_prior = True))>
accuracy(sk_classifier, test_feats)

Ausgabe

0.885

Präzision messen und zurückrufen

Während des Trainings verschiedener Klassifikatoren haben wir auch deren Genauigkeit gemessen. Abgesehen von der Genauigkeit gibt es jedoch eine Reihe anderer Metriken, die zur Bewertung der Klassifizierer verwendet werden. Zwei dieser Metriken sindprecision und recall.

Beispiel

In diesem Beispiel berechnen wir die Genauigkeit und den Rückruf der NaiveBayesClassifier-Klasse, die wir zuvor trainiert haben. Um dies zu erreichen, erstellen wir eine Funktion namens metics_PR (), die zwei Argumente akzeptiert, eines ist der trainierte Klassifikator und das andere sind die gekennzeichneten Testfunktionen. Beide Argumente sind dieselben wie bei der Berechnung der Genauigkeit der Klassifikatoren.

import collections
from nltk import metrics
def metrics_PR(classifier, testfeats):
   refsets = collections.defaultdict(set)
   testsets = collections.defaultdict(set)
   for i, (feats, label) in enumerate(testfeats):
      refsets[label].add(i)
      observed = classifier.classify(feats)
         testsets[observed].add(i)
   precisions = {}
   recalls = {}
   for label in classifier.labels():
   precisions[label] = metrics.precision(refsets[label],testsets[label])
   recalls[label] = metrics.recall(refsets[label], testsets[label])
   return precisions, recalls

Rufen wir diese Funktion auf, um die Präzision und den Rückruf zu ermitteln.

from metrics_classification import metrics_PR
nb_precisions, nb_recalls = metrics_PR(nb_classifier,test_feats)
nb_precisions['pos']

Ausgabe

0.6713532466435213

Beispiel

nb_precisions['neg']

Ausgabe

0.9676271186440678

Beispiel

nb_recalls['pos']

Ausgabe

0.96

Beispiel

nb_recalls['neg']

Ausgabe

0.478

Kombination von Klassifikator und Abstimmung

Das Kombinieren von Klassifizierern ist eine der besten Möglichkeiten, um die Klassifizierungsleistung zu verbessern. Und die Abstimmung ist eine der besten Möglichkeiten, mehrere Klassifikatoren zu kombinieren. Für die Abstimmung benötigen wir eine ungerade Anzahl von Klassifikatoren. Im folgenden Python-Rezept werden drei Klassifizierer kombiniert, nämlich die NaiveBayesClassifier-Klasse, die DecisionTreeClassifier-Klasse und die MaxentClassifier-Klasse.

Um dies zu erreichen, definieren wir eine Funktion namensoting_classifiers () wie folgt.

import itertools
from nltk.classify import ClassifierI
from nltk.probability import FreqDist
class Voting_classifiers(ClassifierI):
   def __init__(self, *classifiers):
      self._classifiers = classifiers
      self._labels = sorted(set(itertools.chain(*[c.labels() for c in classifiers])))
   def labels(self):
      return self._labels
   def classify(self, feats):
      counts = FreqDist()
      for classifier in self._classifiers:
         counts[classifier.classify(feats)] += 1
      return counts.max()

Nennen wir diese Funktion, um drei Klassifikatoren zu kombinieren und die Genauigkeit zu ermitteln -

from vote_classification import Voting_classifiers
combined_classifier = Voting_classifiers(NBC, decisiont_classifier, maxent_classifier)
combined_classifier.labels()

Ausgabe

['neg', 'pos']

Beispiel

accuracy(combined_classifier, test_feats)

Ausgabe

0.948

Aus der obigen Ausgabe können wir ersehen, dass die kombinierten Klassifizierer die höchste Genauigkeit als die einzelnen Klassifizierer hatten.