KI mit Python - Neuronale Netze

Neuronale Netze sind parallele Computergeräte, mit denen versucht wird, ein Computermodell des Gehirns zu erstellen. Das Hauptziel dahinter ist die Entwicklung eines Systems, mit dem verschiedene Rechenaufgaben schneller als mit herkömmlichen Systemen ausgeführt werden können. Diese Aufgaben umfassen Mustererkennung und -klassifizierung, Approximation, Optimierung und Datenclustering.

Was sind künstliche neuronale Netze (ANN)?

Das künstliche neuronale Netz (ANN) ist ein effizientes Computersystem, dessen zentrales Thema der Analogie biologischer neuronaler Netze entlehnt ist. ANNs werden auch als künstliche neuronale Systeme, parallele verteilte Verarbeitungssysteme und verbindungsorientierte Systeme bezeichnet. ANN erwirbt eine große Sammlung von Einheiten, die in einem bestimmten Muster miteinander verbunden sind, um die Kommunikation zwischen ihnen zu ermöglichen. Diese Einheiten werden auch als bezeichnetnodes oder neuronssind einfache Prozessoren, die parallel arbeiten.

Jedes Neuron ist durch a mit einem anderen Neuron verbunden connection link. Jeder Verbindungsverbindung ist ein Gewicht zugeordnet, das die Informationen über das Eingangssignal enthält. Dies ist die nützlichste Information für Neuronen, um ein bestimmtes Problem zu lösen, weil dieweightErregt oder hemmt normalerweise das übertragene Signal. Jedes Neuron hat seinen inneren Zustand, der aufgerufen wirdactivation signal. Ausgangssignale, die nach dem Kombinieren von Eingangssignalen und Aktivierungsregel erzeugt werden, können an andere Einheiten gesendet werden.

Wenn Sie neuronale Netze im Detail untersuchen möchten, können Sie dem Link - Künstliches neuronales Netz - folgen .

Nützliche Pakete installieren

Zum Erstellen neuronaler Netze in Python können wir ein leistungsstarkes Paket für neuronale Netze verwenden, das als bezeichnet wird NeuroLab. Es ist eine Bibliothek grundlegender Algorithmen für neuronale Netze mit flexiblen Netzwerkkonfigurationen und Lernalgorithmen für Python. Sie können dieses Paket mit Hilfe des folgenden Befehls an der Eingabeaufforderung installieren:

pip install NeuroLab

Wenn Sie die Anaconda-Umgebung verwenden, installieren Sie NeuroLab mit dem folgenden Befehl:

conda install -c labfabulous neurolab

Aufbau neuronaler Netze

Lassen Sie uns in diesem Abschnitt einige neuronale Netze in Python mithilfe des NeuroLab-Pakets erstellen.

Perceptron-basierter Klassifikator

Perceptrons sind die Bausteine ​​von ANN. Wenn Sie mehr über Perceptron erfahren möchten, folgen Sie dem Link - künstliches_neurales_Netzwerk

Es folgt eine schrittweise Ausführung des Python-Codes zum Erstellen eines einfachen Perceptron-basierten Klassifikators für neuronale Netze -

Importieren Sie die erforderlichen Pakete wie gezeigt -

import matplotlib.pyplot as plt
import neurolab as nl

Geben Sie die Eingabewerte ein. Beachten Sie, dass dies ein Beispiel für überwachtes Lernen ist. Daher müssen Sie auch Zielwerte angeben.

input = [[0, 0], [0, 1], [1, 0], [1, 1]]
target = [[0], [0], [0], [1]]

Erstellen Sie das Netzwerk mit 2 Eingängen und 1 Neuron -

net = nl.net.newp([[0, 1],[0, 1]], 1)

Trainieren Sie jetzt das Netzwerk. Hier verwenden wir die Delta-Regel für das Training.

error_progress = net.train(input, target, epochs=100, show=10, lr=0.1)

Visualisieren Sie nun die Ausgabe und zeichnen Sie das Diagramm -

plt.figure()
plt.plot(error_progress)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.grid()
plt.show()

Sie können die folgende Grafik sehen, die den Trainingsfortschritt anhand der Fehlermetrik zeigt -

Einschichtige neuronale Netze

In diesem Beispiel erstellen wir ein einschichtiges neuronales Netzwerk, das aus unabhängigen Neuronen besteht, die auf Eingabedaten einwirken, um die Ausgabe zu erzeugen. Beachten Sie, dass wir die genannte Textdatei verwendenneural_simple.txt als unser Input.

Importieren Sie die nützlichen Pakete wie gezeigt -

import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl

Laden Sie den Datensatz wie folgt:

input_data = np.loadtxt(“/Users/admin/neural_simple.txt')

Das Folgende sind die Daten, die wir verwenden werden. Beachten Sie, dass in diesen Daten die ersten beiden Spalten die Features und die letzten beiden Spalten die Beschriftungen sind.

array([[2. , 4. , 0. , 0. ],
      [1.5, 3.9, 0. , 0. ],
      [2.2, 4.1, 0. , 0. ],
      [1.9, 4.7, 0. , 0. ],
      [5.4, 2.2, 0. , 1. ],
      [4.3, 7.1, 0. , 1. ],
      [5.8, 4.9, 0. , 1. ],
      [6.5, 3.2, 0. , 1. ],
      [3. , 2. , 1. , 0. ],
      [2.5, 0.5, 1. , 0. ],
      [3.5, 2.1, 1. , 0. ],
      [2.9, 0.3, 1. , 0. ],
      [6.5, 8.3, 1. , 1. ],
      [3.2, 6.2, 1. , 1. ],
      [4.9, 7.8, 1. , 1. ],
      [2.1, 4.8, 1. , 1. ]])

Trennen Sie diese vier Spalten nun in 2 Datenspalten und 2 Beschriftungen.

data = input_data[:, 0:2]
labels = input_data[:, 2:]

Zeichnen Sie die Eingabedaten mit den folgenden Befehlen:

plt.figure()
plt.scatter(data[:,0], data[:,1])
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Input data')

Definieren Sie nun die minimalen und maximalen Werte für jede Dimension wie hier gezeigt -

dim1_min, dim1_max = data[:,0].min(), data[:,0].max()
dim2_min, dim2_max = data[:,1].min(), data[:,1].max()

Definieren Sie als Nächstes die Anzahl der Neuronen in der Ausgabeschicht wie folgt:

nn_output_layer = labels.shape[1]

Definieren Sie nun ein einschichtiges neuronales Netzwerk -

dim1 = [dim1_min, dim1_max]
dim2 = [dim2_min, dim2_max]
neural_net = nl.net.newp([dim1, dim2], nn_output_layer)

Trainieren Sie das neuronale Netzwerk mit der Anzahl der Epochen und der Lernrate wie gezeigt -

error = neural_net.train(data, labels, epochs = 200, show = 20, lr = 0.01)

Visualisieren und zeichnen Sie nun den Trainingsfortschritt mit den folgenden Befehlen:

plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.title('Training error progress')
plt.grid()
plt.show()

Verwenden Sie nun die Testdatenpunkte im obigen Klassifikator -

print('\nTest Results:')
data_test = [[1.5, 3.2], [3.6, 1.7], [3.6, 5.7],[1.6, 3.9]] for item in data_test:
   print(item, '-->', neural_net.sim([item])[0])

Die Testergebnisse finden Sie hier -

[1.5, 3.2] --> [1. 0.]
[3.6, 1.7] --> [1. 0.]
[3.6, 5.7] --> [1. 1.]
[1.6, 3.9] --> [1. 0.]

Sie können die folgenden Grafiken als Ausgabe des bisher diskutierten Codes sehen -

Mehrschichtige neuronale Netze

In diesem Beispiel erstellen wir ein mehrschichtiges neuronales Netzwerk, das aus mehr als einer Schicht besteht, um die zugrunde liegenden Muster in den Trainingsdaten zu extrahieren. Dieses mehrschichtige neuronale Netzwerk funktioniert wie ein Regressor. Wir werden einige Datenpunkte basierend auf der Gleichung generieren: y = 2x 2 +8.

Importieren Sie die erforderlichen Pakete wie gezeigt -

import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl

Generieren Sie einen Datenpunkt basierend auf der oben genannten Gleichung -

min_val = -30
max_val = 30
num_points = 160
x = np.linspace(min_val, max_val, num_points)
y = 2 * np.square(x) + 8
y /= np.linalg.norm(y)

Formen Sie diesen Datensatz nun wie folgt um:

data = x.reshape(num_points, 1)
labels = y.reshape(num_points, 1)

Visualisieren und zeichnen Sie den Eingabedatensatz mit den folgenden Befehlen:

plt.figure()
plt.scatter(data, labels)
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Data-points')

Bauen Sie nun das neuronale Netzwerk mit zwei versteckten Schichten auf neurolab mit ten Neuronen in der ersten verborgenen Schicht, six in der zweiten versteckten Schicht und one in der Ausgabeebene.

neural_net = nl.net.newff([[min_val, max_val]], [10, 6, 1])

Verwenden Sie nun den Gradiententrainingsalgorithmus -

neural_net.trainf = nl.train.train_gd

Trainieren Sie nun das Netzwerk mit dem Ziel, anhand der oben generierten Daten zu lernen -

error = neural_net.train(data, labels, epochs = 1000, show = 100, goal = 0.01)

Führen Sie nun die neuronalen Netze auf den Trainingsdatenpunkten aus -

output = neural_net.sim(data)
y_pred = output.reshape(num_points)

Jetzt Plot- und Visualisierungsaufgabe -

plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Error')
plt.title('Training error progress')

Jetzt zeichnen wir die tatsächliche gegenüber der vorhergesagten Ausgabe auf -

x_dense = np.linspace(min_val, max_val, num_points * 2)
y_dense_pred = neural_net.sim(x_dense.reshape(x_dense.size,1)).reshape(x_dense.size)
plt.figure()
plt.plot(x_dense, y_dense_pred, '-', x, y, '.', x, y_pred, 'p')
plt.title('Actual vs predicted')
plt.show()

Als Ergebnis der obigen Befehle können Sie die Diagramme wie unten gezeigt betrachten -