Python을 사용한 AI – 신경망
신경망은 뇌의 컴퓨터 모델을 만들려는 시도 인 병렬 컴퓨팅 장치입니다. 기본 목표는 기존 시스템보다 빠르게 다양한 계산 작업을 수행 할 수있는 시스템을 개발하는 것입니다. 이러한 작업에는 패턴 인식 및 분류, 근사화, 최적화 및 데이터 클러스터링이 포함됩니다.
인공 신경망 (ANN)이란?
인공 신경망 (ANN)은 생물학적 신경망의 비유에서 차용 한 중심 주제를 가진 효율적인 컴퓨팅 시스템입니다. ANN은 인공 신경 시스템, 병렬 분산 처리 시스템 및 연결 시스템이라고도합니다. ANN은 그들 사이의 통신을 허용하기 위해 어떤 패턴으로 상호 연결되어있는 대규모 단위 집합을 획득합니다. 이러한 단위는nodes 또는 neurons, 병렬로 작동하는 간단한 프로세서입니다.
모든 뉴런은 connection link. 각 연결 링크는 입력 신호에 대한 정보가있는 가중치와 연관됩니다. 이것은 뉴런이 특정 문제를 해결하는 데 가장 유용한 정보입니다.weight일반적으로 전달되는 신호를 자극하거나 억제합니다. 각 뉴런은 내부 상태를 가지고 있습니다.activation signal. 입력 신호와 활성화 규칙을 결합하여 생성 된 출력 신호를 다른 장치로 보낼 수 있습니다.
신경망을 자세히 연구하려면 인공 신경망 링크를 따를 수 있습니다 .
유용한 패키지 설치
Python에서 신경망을 만들기 위해 우리는 신경망을위한 강력한 패키지를 사용할 수 있습니다. NeuroLab. 유연한 네트워크 구성 및 Python 용 학습 알고리즘을 갖춘 기본 신경망 알고리즘 라이브러리입니다. 명령 프롬프트에서 다음 명령을 사용하여이 패키지를 설치할 수 있습니다.
pip install NeuroLab
Anaconda 환경을 사용하는 경우 다음 명령을 사용하여 NeuroLab을 설치하십시오.
conda install -c labfabulous neurolab
신경망 구축
이 섹션에서는 NeuroLab 패키지를 사용하여 Python에서 신경망을 구축해 보겠습니다.
퍼셉트론 기반 분류기
퍼셉트론은 ANN의 빌딩 블록입니다. Perceptron에 대해 더 알고 싶으시면, Artificial_neural_network 링크를 따라갈 수 있습니다.
다음은 간단한 신경망 퍼셉트론 기반 분류기를 구축하기위한 Python 코드의 단계적 실행입니다.
표시된대로 필요한 패키지를 가져옵니다.
import matplotlib.pyplot as plt
import neurolab as nl
입력 값을 입력하십시오. 지도 학습의 예이므로 목표 값도 제공해야합니다.
input = [[0, 0], [0, 1], [1, 0], [1, 1]]
target = [[0], [0], [0], [1]]
2 개의 입력과 1 개의 뉴런으로 네트워크 만들기 −
net = nl.net.newp([[0, 1],[0, 1]], 1)
이제 네트워크를 훈련 시키십시오. 여기에서는 훈련에 델타 규칙을 사용합니다.
error_progress = net.train(input, target, epochs=100, show=10, lr=0.1)
이제 출력을 시각화하고 그래프를 플로팅합니다.
plt.figure()
plt.plot(error_progress)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.grid()
plt.show()
오류 메트릭을 사용하여 훈련 진행 상황을 보여주는 다음 그래프를 볼 수 있습니다.
단일 계층 신경망
이 예에서는 출력을 생성하기 위해 입력 데이터에 작용하는 독립 뉴런으로 구성된 단일 계층 신경망을 생성합니다. 우리는 텍스트 파일을 사용하고 있습니다.neural_simple.txt 우리의 입력으로.
다음과 같이 유용한 패키지를 가져옵니다.
import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl
다음과 같이 데이터 세트를로드하십시오-
input_data = np.loadtxt(“/Users/admin/neural_simple.txt')
다음은 우리가 사용할 데이터입니다. 이 데이터에서 처음 두 열은 특성이고 마지막 두 열은 레이블입니다.
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. ]])
이제이 4 개의 열을 2 개의 데이터 열과 2 개의 레이블로 분리합니다.
data = input_data[:, 0:2]
labels = input_data[:, 2:]
다음 명령을 사용하여 입력 데이터를 플로팅-
plt.figure()
plt.scatter(data[:,0], data[:,1])
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Input data')
이제 여기에 표시된대로 각 차원의 최소값과 최대 값을 정의합니다.
dim1_min, dim1_max = data[:,0].min(), data[:,0].max()
dim2_min, dim2_max = data[:,1].min(), data[:,1].max()
다음으로 다음과 같이 출력 계층의 뉴런 수를 정의합니다.
nn_output_layer = labels.shape[1]
이제 단일 계층 신경망을 정의하십시오.
dim1 = [dim1_min, dim1_max]
dim2 = [dim2_min, dim2_max]
neural_net = nl.net.newp([dim1, dim2], nn_output_layer)
다음과 같이 epoch 수와 학습률로 신경망을 훈련시킵니다.
error = neural_net.train(data, labels, epochs = 200, show = 20, lr = 0.01)
이제 다음 명령을 사용하여 훈련 진행 상황을 시각화하고 플로팅합니다.
plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.title('Training error progress')
plt.grid()
plt.show()
이제 위의 분류기에서 테스트 데이터 포인트를 사용하십시오.
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])
여기에 표시된대로 테스트 결과를 찾을 수 있습니다.
[1.5, 3.2] --> [1. 0.]
[3.6, 1.7] --> [1. 0.]
[3.6, 5.7] --> [1. 1.]
[1.6, 3.9] --> [1. 0.]
지금까지 논의 된 코드의 출력으로 다음 그래프를 볼 수 있습니다.
다층 신경망
이 예에서는 훈련 데이터의 기본 패턴을 추출하기 위해 둘 이상의 레이어로 구성된 다층 신경망을 생성합니다. 이 다층 신경망은 회귀 자처럼 작동합니다. 방정식을 기반으로 몇 가지 데이터 포인트를 생성 할 것입니다 : y = 2x 2 +8.
표시된대로 필요한 패키지를 가져옵니다.
import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl
위에서 언급 한 방정식을 기반으로 일부 데이터 포인트 생성-
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)
이제이 데이터 세트를 다음과 같이 재구성합니다.
data = x.reshape(num_points, 1)
labels = y.reshape(num_points, 1)
다음 명령을 사용하여 입력 데이터 세트를 시각화하고 플로팅합니다.
plt.figure()
plt.scatter(data, labels)
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Data-points')
이제 두 개의 은닉 계층이있는 신경망을 구축합니다. neurolab 와 ten 첫 번째 은닉층의 뉴런, six 두 번째 히든 레이어에서 one 출력 레이어에서.
neural_net = nl.net.newff([[min_val, max_val]], [10, 6, 1])
이제 그라디언트 훈련 알고리즘을 사용하십시오.
neural_net.trainf = nl.train.train_gd
이제 위에서 생성 된 데이터를 학습하는 것을 목표로 네트워크를 훈련 시키십시오.
error = neural_net.train(data, labels, epochs = 1000, show = 100, goal = 0.01)
이제 훈련 데이터 포인트에서 신경망을 실행합니다.
output = neural_net.sim(data)
y_pred = output.reshape(num_points)
이제 플롯 및 시각화 작업-
plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Error')
plt.title('Training error progress')
이제 우리는 실제 결과와 예측 결과를 그릴 것입니다.
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()
위 명령의 결과로 아래와 같이 그래프를 관찰 할 수 있습니다.