인공 신경망

인공 신경망 또는 간단히 신경망은 새로운 아이디어가 아닙니다. 그것은 약 80 년 동안 존재했습니다.

2011 년이 되어서야 Deep Neural Networks가 새로운 기술, 방대한 데이터 세트 가용성 및 강력한 컴퓨터의 사용으로 인기를 얻었습니다.

신경망은 수상 돌기, 핵, 축삭 및 말단 축삭을 가진 뉴런을 모방합니다.

네트워크의 경우 두 개의 뉴런이 필요합니다. 이 뉴런은 하나의 수상 돌기와 다른 하나의 말단 축삭 사이의 시냅스를 통해 정보를 전달합니다.

인공 뉴런의 가능한 모델은 다음과 같습니다.

신경망은 아래와 같이 보입니다.

원은 데이터에 대한 기능을 가진 뉴런 또는 노드이며 이들을 연결하는 선 / 가장자리는 전달되는 가중치 / 정보입니다.

각 열은 레이어입니다. 데이터의 첫 번째 레이어는 입력 레이어입니다. 그러면 입력 레이어와 출력 레이어 사이의 모든 레이어가 히든 레이어가됩니다.

히든 레이어가 하나 또는 몇 개있는 경우 얕은 신경망이 있습니다. 히든 레이어가 많으면 심층 신경망이있는 것입니다.

이 모델에는 입력 데이터가 있고 가중치를 부여한 다음 임계 값 함수 또는 활성화 함수라고하는 뉴런의 함수를 통해 전달합니다.

기본적으로 특정 값과 비교하여 모든 값의 합계입니다. 신호를 발동하면 결과는 (1) 출력되거나 아무것도 발동되지 않은 경우 (0)입니다. 그런 다음 가중치가 부여되고 다음 뉴런으로 전달되고 동일한 종류의 기능이 실행됩니다.

활성화 함수로 시그 모이 드 (s 자형) 함수를 가질 수 있습니다.

가중치는 무작위로 시작할 뿐이며 노드 / 뉴런에 대한 입력마다 고유합니다.

가장 기본적인 유형의 신경망 인 일반적인 "피드 포워드"에서 정보를 생성 한 네트워크를 통해 직접 전달하고 출력이 샘플 데이터를 사용했을 것으로 기대했던 출력과 비교합니다.

여기에서 원하는 출력과 일치하도록 출력을 얻을 수 있도록 가중치를 조정해야합니다.

신경망을 통해 데이터를 직접 전송하는 행위를 feed forward neural network.

우리의 데이터는 입력에서 레이어로, 순서대로 출력으로 이동합니다.

뒤로 돌아가서 손실 / 비용을 최소화하기 위해 가중치를 조정하기 시작할 때 이것을 back propagation.

이것은 optimization problem. 신경망을 사용하면 실제로는 수십만 개 또는 수백만 개 이상의 변수를 처리해야합니다.

첫 번째 해결책은 최적화 방법으로 확률 적 경사 하강 법을 사용하는 것이 었습니다. 이제 AdaGrad, Adam Optimizer 등과 같은 옵션이 있습니다. 어느 쪽이든 이것은 엄청난 계산 작업입니다. 그렇기 때문에 신경망은 대부분 반세기 이상 선반에 남아있었습니다. 이 작업을 수행하는 것을 고려할 수있는 능력과 아키텍처를 기계에 갖고 있고 적절한 크기의 데이터 세트를 일치시킨 것은 아주 최근의 일이었습니다.

간단한 분류 작업의 경우 신경망은 K Nearest Neighbors와 같은 다른 간단한 알고리즘과 성능면에서 비교적 유사합니다. 신경망의 실제 유용성은 우리가 훨씬 더 큰 데이터와 훨씬 더 복잡한 질문을 가질 때 실현되며, 두 가지 모두 다른 기계 학습 모델을 능가합니다.