딥 러닝 모델 생성

우리의 신경망 모델은 계층의 선형 스택으로 구성됩니다. 그러한 모델을 정의하기 위해 우리는Sequential 기능-

model = Sequential()

입력 레이어

다음 프로그램 명령문을 사용하여 네트워크의 첫 번째 계층 인 입력 계층을 정의합니다.

model.add(Dense(512, input_shape=(784,)))

이렇게하면 784 개의 입력 노드가있는 512 개의 노드 (뉴런)가있는 계층이 생성됩니다. 이것은 아래 그림에 묘사되어 있습니다-

모든 입력 노드는 레이어 1에 완전히 연결되어 있습니다. 즉, 각 입력 노드는 레이어 1의 모든 512 노드에 연결됩니다.

다음으로, 레이어 1의 출력에 대한 활성화 기능을 추가해야합니다. 활성화로 ReLU를 사용할 것입니다. 활성화 기능은 다음 프로그램 문을 사용하여 추가됩니다-

model.add(Activation('relu'))

다음으로, 아래 문장을 사용하여 Dropout 20 %를 추가합니다. 드롭 아웃은 모델이 과적 합되는 것을 방지하는 데 사용되는 기술입니다.

model.add(Dropout(0.2))

이 시점에서 입력 레이어가 완전히 정의되었습니다. 다음으로 숨겨진 레이어를 추가합니다.

숨겨진 레이어

숨겨진 레이어는 512 개의 노드로 구성됩니다. 히든 레이어에 대한 입력은 이전에 정의 된 입력 레이어에서 나옵니다. 모든 노드는 이전의 경우와 같이 완전히 연결됩니다. 히든 레이어의 출력은 네트워크의 다음 레이어로 이동하여 최종 레이어와 출력 레이어가됩니다. 이전 계층과 동일한 ReLU 활성화와 20 % 드롭 아웃을 사용합니다. 이 레이어를 추가하는 코드는 다음과 같습니다.

model.add(Dense(512))
model.add(Activation('relu'))
model.add(Dropout(0.2))

이 단계의 네트워크는 다음과 같이 시각화 할 수 있습니다.

다음으로 네트워크에 출력 계층 인 최종 계층을 추가합니다. 여기서 사용한 것과 유사한 코드를 사용하여 숨겨진 레이어를 얼마든지 추가 할 수 있습니다. 더 많은 계층을 추가하면 훈련을 위해 네트워크가 복잡해집니다. 그러나 전부는 아니지만 많은 경우에 더 나은 결과의 확실한 이점을 제공합니다.

출력 레이어

출력 레이어는 주어진 이미지를 10 개의 고유 한 숫자로 분류하기 위해 단 10 개의 노드로 구성됩니다. 다음 문을 사용하여이 레이어를 추가합니다.

model.add(Dense(10))

출력을 10 개의 개별 단위로 분류하기 위해 소프트 맥스 활성화를 사용합니다. ReLU의 경우 출력은 바이너리입니다. 다음 문을 사용하여 활성화를 추가합니다.

model.add(Activation('softmax'))

이 시점에서 우리의 네트워크는 아래 다이어그램과 같이 시각화 될 수 있습니다.

이 시점에서 우리의 네트워크 모델은 소프트웨어에서 완전히 정의됩니다. 코드 셀을 실행하고 오류가 없으면 아래 스크린 샷과 같이 화면에 확인 메시지가 표시됩니다.

다음으로 모델을 컴파일해야합니다.