Keras - Überblick über Deep Learning
Deep Learning ist ein sich entwickelndes Teilgebiet des maschinellen Lernens. Beim Deep Learning wird die Eingabe Schicht für Schicht analysiert, wobei jede Schicht nach und nach Informationen auf höherer Ebene über die Eingabe extrahiert.
Nehmen wir ein einfaches Szenario für die Analyse eines Bildes. Nehmen wir an, Ihr Eingabebild ist in ein rechteckiges Pixelraster unterteilt. Jetzt abstrahiert die erste Ebene die Pixel. Die zweite Ebene versteht die Kanten im Bild. Die nächste Ebene erstellt Knoten aus den Kanten. Dann würde der nächste Zweige von den Knoten finden. Schließlich erkennt die Ausgabeebene das vollständige Objekt. Hier geht der Merkmalsextraktionsprozess von der Ausgabe einer Schicht in die Eingabe der nächsten nachfolgenden Schicht.
Mit diesem Ansatz können wir eine Vielzahl von Funktionen verarbeiten, was Deep Learning zu einem sehr leistungsfähigen Werkzeug macht. Deep-Learning-Algorithmen sind auch nützlich für die Analyse unstrukturierter Daten. Lassen Sie uns in diesem Kapitel die Grundlagen des tiefen Lernens durchgehen.
Künstliche neurale Netzwerke
Der beliebteste und wichtigste Ansatz für tiefes Lernen ist die Verwendung des „Künstlichen Neuronalen Netzwerks“ (ANN). Sie sind vom Modell des menschlichen Gehirns inspiriert, das das komplexeste Organ unseres Körpers ist. Das menschliche Gehirn besteht aus mehr als 90 Milliarden winzigen Zellen, die als „Neuronen“ bezeichnet werden. Neuronen sind durch Nervenfasern miteinander verbunden, die als "Axone" und "Dendriten" bezeichnet werden. Die Hauptaufgabe des Axons besteht darin, Informationen von einem Neuron zu einem anderen zu übertragen, mit dem es verbunden ist.
In ähnlicher Weise besteht die Hauptaufgabe von Dendriten darin, die Informationen zu empfangen, die von den Axonen eines anderen Neurons übertragen werden, mit dem sie verbunden sind. Jedes Neuron verarbeitet eine kleine Information und gibt das Ergebnis dann an ein anderes Neuron weiter. Dieser Prozess wird fortgesetzt. Dies ist die grundlegende Methode, die unser menschliches Gehirn verwendet, um Informationen wie Sprache, Bild usw. zu verarbeiten und nützliche Informationen daraus zu extrahieren.
Basierend auf diesem Modell wurde das erste künstliche neuronale Netzwerk (ANN) vom Psychologen erfunden Frank Rosenblatt, im Jahr 1958. ANNs bestehen aus mehreren Knoten, die Neuronen ähnlich sind. Knoten sind eng miteinander verbunden und in verschiedenen verborgenen Schichten organisiert. Die Eingabeschicht empfängt die Eingabedaten und die Daten durchlaufen nacheinander eine oder mehrere verborgene Schichten, und schließlich sagt die Ausgabeschicht etwas Nützliches über die Eingabedaten voraus. Zum Beispiel kann die Eingabe ein Bild sein und die Ausgabe kann das im Bild identifizierte Objekt sein, beispielsweise eine "Katze".
Ein einzelnes Neuron (in ANN als Perzeptron bezeichnet) kann wie folgt dargestellt werden:
Hier,
Mehrfacheingabe zusammen mit Gewicht repräsentiert Dendriten.
Die Summe der Eingaben zusammen mit der Aktivierungsfunktion repräsentiert Neuronen. Sum bedeutet eigentlich, dass der berechnete Wert aller Eingänge und die Aktivierungsfunktion eine Funktion darstellen, die die modifiziert Sum Wert in 0, 1 oder 0 bis 1.
Die tatsächliche Ausgabe stellt das Axon dar und die Ausgabe wird vom Neuron in der nächsten Schicht empfangen.
Lassen Sie uns in diesem Abschnitt verschiedene Arten künstlicher neuronaler Netze verstehen.
Mehrschichtiges Perzeptron
Mehrschichtiges Perzeptron ist die einfachste Form von ANN. Es besteht aus einer einzelnen Eingabeebene, einer oder mehreren verborgenen Ebenen und schließlich einer Ausgabeebene. Eine Schicht besteht aus einer Sammlung von Perzeptron. Die Eingabeebene ist im Grunde ein oder mehrere Merkmale der Eingabedaten. Jede verborgene Schicht besteht aus einem oder mehreren Neuronen und verarbeitet bestimmte Aspekte des Merkmals und sendet die verarbeiteten Informationen an die nächste verborgene Schicht. Der Ausgabeschichtprozess empfängt die Daten von der letzten verborgenen Schicht und gibt schließlich das Ergebnis aus.
Faltungs-Neuronales Netz (CNN)
Das Faltungs-Neuronale Netz ist eines der beliebtesten ANN. Es ist weit verbreitet in den Bereichen Bild- und Videoerkennung. Es basiert auf dem Konzept der Faltung, einem mathematischen Konzept. Es ist dem mehrschichtigen Perzeptron fast ähnlich, außer dass es eine Reihe von Faltungsschichten und Poolschichten vor der vollständig verbundenen verborgenen Neuronenschicht enthält. Es hat drei wichtige Schichten -
Convolution layer - Es ist der primäre Baustein und führt Rechenaufgaben basierend auf der Faltungsfunktion aus.
Pooling layer - Es ist neben der Faltungsschicht angeordnet und wird verwendet, um die Größe der Eingaben zu reduzieren, indem unnötige Informationen entfernt werden, damit die Berechnung schneller durchgeführt werden kann.
Fully connected layer - Es ist neben einer Reihe von Faltungs- und Pooling-Schichten angeordnet und klassifiziert Eingaben in verschiedene Kategorien.
Ein einfaches CNN kann wie folgt dargestellt werden:
Hier,
Es werden 2 Serien von Faltungs- und Pooling-Schichten verwendet, die die Eingabe (z. B. Bild) empfangen und verarbeiten.
Eine einzelne vollständig verbundene Schicht wird verwendet und zur Ausgabe der Daten verwendet (z. B. Klassifizierung des Bildes).
Recurrent Neural Network (RNN)
Wiederkehrende neuronale Netze (RNN) sind nützlich, um den Fehler in anderen ANN-Modellen zu beheben. Nun, die meisten ANN erinnern sich nicht an die Schritte aus früheren Situationen und haben gelernt, Entscheidungen basierend auf dem Kontext im Training zu treffen. In der Zwischenzeit speichert RNN die Informationen der Vergangenheit und alle seine Entscheidungen werden aus dem getroffen, was es aus der Vergangenheit gelernt hat.
Dieser Ansatz ist hauptsächlich bei der Bildklassifizierung nützlich. Manchmal müssen wir in die Zukunft schauen, um die Vergangenheit zu reparieren. In diesem Fall ist bidirektionales RNN hilfreich, um aus der Vergangenheit zu lernen und die Zukunft vorherzusagen. Zum Beispiel haben wir handgeschriebene Beispiele in mehreren Eingaben. Angenommen, wir haben Verwirrung in einer Eingabe, dann müssen wir andere Eingaben erneut überprüfen, um den richtigen Kontext zu erkennen, der die Entscheidung aus der Vergangenheit trifft.
Workflow von ANN
Lassen Sie uns zuerst die verschiedenen Phasen des tiefen Lernens verstehen und dann lernen, wie Keras beim Prozess des tiefen Lernens hilft.
Sammeln Sie die erforderlichen Daten
Deep Learning erfordert viele Eingabedaten, um das Ergebnis erfolgreich zu lernen und vorherzusagen. Sammeln Sie also zuerst so viele Daten wie möglich.
Daten analysieren
Analysieren Sie die Daten und erhalten Sie ein gutes Verständnis der Daten. Das bessere Verständnis der Daten ist erforderlich, um den richtigen ANN-Algorithmus auszuwählen.
Wählen Sie einen Algorithmus (Modell)
Wählen Sie einen Algorithmus, der am besten zu der Art des Lernprozesses (z. B. Bildklassifizierung, Textverarbeitung usw.) und den verfügbaren Eingabedaten passt. Algorithmus wird dargestellt durchModelin Keras. Der Algorithmus umfasst eine oder mehrere Schichten. Jede Schicht in ANN kann durch dargestellt werdenKeras Layer in Keras.
Prepare data - Verarbeiten, filtern und wählen Sie nur die erforderlichen Informationen aus den Daten aus.
Split data- Teilen Sie die Daten in Trainings- und Testdatensätze auf. Testdaten werden verwendet, um die Vorhersage des Algorithmus / Modells (sobald die Maschine gelernt hat) zu bewerten und die Effizienz des Lernprozesses zu überprüfen.
Compile the model- Kompilieren Sie den Algorithmus / das Modell so, dass es weiter verwendet werden kann, um durch Training zu lernen und schließlich Vorhersagen zu treffen. Für diesen Schritt müssen wir die Verlustfunktion und den Optimierer auswählen. Verlustfunktion und Optimierer werden in der Lernphase verwendet, um den Fehler (Abweichung von der tatsächlichen Ausgabe) zu finden und zu optimieren, damit der Fehler minimiert wird.
Fit the model - Der eigentliche Lernprozess wird in dieser Phase anhand des Trainingsdatensatzes durchgeführt.
Predict result for unknown value - Vorhersage der Ausgabe für die unbekannten Eingabedaten (außer vorhandenen Trainings- und Testdaten)
Evaluate model - Bewerten Sie das Modell, indem Sie die Ausgabe für Testdaten vorhersagen und die Vorhersage mit dem tatsächlichen Ergebnis der Testdaten vergleichen.
Freeze, Modify or choose new algorithm- Überprüfen Sie, ob die Bewertung des Modells erfolgreich ist. Wenn ja, speichern Sie den Algorithmus für zukünftige Vorhersagezwecke. Wenn nicht, ändern oder wählen Sie einen neuen Algorithmus / ein neues Modell und trainieren, prognostizieren und bewerten Sie das Modell erneut. Wiederholen Sie den Vorgang, bis der beste Algorithmus (Modell) gefunden ist.
Die obigen Schritte können mithilfe des folgenden Flussdiagramms dargestellt werden: