디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

마구잡이로 만드는 단층 퍼셉트론

생각놀이갤로그로 이동합니다. 2012.02.18 14:52:25
조회 570 추천 3 댓글 3


  보통 뉴럴네트워크라고 하면 굉장히 어려운 것 이라고 생각하는 경우가 많은 것 같음


  통상 ANN이라고 불리는 인공신경망은 현재에 와서는 그 종류가 상당히 많고 복잡한 알고리즘이 많아서 처음 하는 사람들이 접근하기 어려움
 
  하지만 초창기의 단층퍼셉트론과 역전파방식으로 학습하는 다층퍼셉트론은 고등학교 수준의 수학만 할 줄 알아도 별 어려움 없이 구현이 가능함 
('구현만' 가능함 -_-;; 수식이 다 유도되어 있어서... )

  신경망에 대한 자세한 내용은 DMW횽의 게시물을 보삼 (솔찍히 이거보다 잘 쓸 자신이 없음;; )
 
  DMW횽의 잉여잉여 퍼셉트론 참조 : https://gall.dcinside.com/list.php?id=programming&no=136419&page=1

 지금부터 만들건 하나의 뉴런을 만들고, 그 뉴런에다가 큼퓨터의 기본적인 연산은 AND와 OR을 각각 학습시켜 볼 거임.

  인공신경망을 구성하는 '뉴런'은 조금 극단적으로 보면 이런식으로 구성되어 있뜸

        출력 =  활성화함수( [입력 벡터] * [가중치 벡터]T - 임계치 )
 

  여기서 T는 Transpose인데 행렬의 행과 열을 바꿔치기 하는 연산이고 벡터는 한줄짜리 행렬을 의미함 -0-

 활성화 함수로는 보통 step함수나 signoide 함수를 사용하는데, signoide함수는 미분이 용이해서 역전파 알고리즘에서 많이 쓰임.

여기에서는 step함수를 사용하고 step함수는 다음과 같이 정의함

 step(x) =    1   , x < 0
                   0  , otherwise

들어가는 x값이 0보다 크면 1이 되는 단위계산 함수임.

결국 뉴런의 정체라는 건 입력벡터와 가중치 벡터의 내적이 미리 정해놓은 임계값을 넘으면 활성화(1출력) 아니면 비활성화(0출력) 하는 블럭인 것임

 여기에서는 임계치는 임의로 정하면 됨 (ex 0.5)
 우리가 만들것은 2개의 입력을 받고 그것의 AND연산을 하여 출력할 수 있는 뉴런 이므로, 뉴런은 결국 다음과 같은 구성이 됨

  Y = step( [x1, x2] * [w1, w2]T  - 0.5 ) 
     = step( x1w1 + x2w2 - 0.5 )

 와.. 짱 단순함 이건 그냥 행렬의 곱셈인 거임.  따라서 우리가 이 뉴런에다가 적절한 w1과 w2값을 넣어주기만 하면, 이 뉴런은 AND함수로도 OR함수로도 동작할 수 있음 (Xor은 안댐;;; 단층 신경망은 선형분리가 불가능한 님은 분류가 불가능함..)

다만 이 한가지 문제가 있음....  바로 w1과 w2값을 모른다는거 ;;;

 이 뉴런이 내가 원하는 함수로 동작하도록 하는 w1고 w2값을 찾기 위해서는, 임의의 입력을 넣고 그 출력을 우리가 원하는 출력과 비교해서 w1,w2값을 우리가 필요한 값으로 근사해 나가는 작업이 필요함.

 우리는 이것을 학습이라고 함.

 학습은 아래의 명료한 공식에 의해 이루어짐 참 여기서 학습률은 한번의 학습에서 가중치가 변화하는 비율인데 적당한 값을 써 주어야 함
너무 크면 학습오차가 커지고, 너무 작으면, 학습이 오래걸리게 됨

 w1 = w1 + 학습률 * x1 * 출력오차
 w2 = w2 + 학습률 * x2 * 출력오차 
출력오차 = 목표출력 - 현재출력값

대충 이런 방식으로, w1과 w2값을 구하고 그 값이 AND연산이 될 때 까지 계속 반복해서 학습을 하면, AND연산을 하는 뉴런이 완성댐..

C로 짜 놓은 소스 첨부함 
---------------------------------------------------------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <math.h> 

double step(double x); //스텝함수 

int main(int argc, char *argv[])
{
  double input[4][2] = {0,0,0,1,1,0,1,1};
  double w[2] = {0.1, 0.9}; //가중치
  double thold = 0.5; // 임계치 
  double x[2]; //입력값
  
  double y = 0; // 결과값 
  const int xnum = 2;//입력값의 개수
  int cnt =0;
  double error = 0; // 에러수치 
 
  double alpa = 0.1; //학습률 
  
  int superloop = 0;
  
  printf("로젠블렛 퍼셉트론 OR연산 학습 n");  
  for(superloop = 0; superloop < 4*6; superloop++)
  {
     for(cnt =0; cnt < xnum; cnt++)x[cnt]=input[superloop%4][cnt];
                
     double sum =0; //선형결합
     for(cnt =0; cnt < xnum; cnt++)  sum += x[cnt]*w[cnt];
  
     y = step(sum - thold);  //하드리미터
  
     //에러값 추출  
     error = (x[0] || x[1]) - y;
  
     //가중치 보정 
     for(cnt =0; cnt < xnum; cnt++) w[cnt] = w[cnt] + alpa * x[cnt] * error; 
  
     if(superloop%4 == 0) printf("n%d 회차n",superloop/4);
     printf("%f  %f 결과값 : %lfn",x[0],x[1],y);
     if(superloop%4 == 3) printf("가중치 : w[0] : %lf , w[1] : %lfn",w[0],w[1]);
}

  [...];        
  return 0;
}

double step(double x)
{
    if( x < 0 ) return 0;
    else return 1; 
}
---------------------------------------------------------------------------------------------------------------


추천 비추천

3

고정닉 0

0

원본 첨부파일 1

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 뛰어난 운동 신경으로 남자와 싸워도 이길 것 같은 여자 스타는? 운영자 25/11/24 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
304326 프갤 탑이 누구냐 [3] vold갤로그로 이동합니다. 12.02.21 116 0
304325 끙...좀 알려주세요 ㅠㅠ.. [3] 코딩...?갤로그로 이동합니다. 12.02.21 50 0
304324 자바로 다른 프로그램 어케 제어해? ㅠ [3] 뉴뉴(115.161) 12.02.21 60 0
304323 ★프로그래머를 3D 업종이라 생각하는분들 보셔요ㅋㅋ★ [5] C왕초보(118.221) 12.02.21 191 0
304322 성님들 php 쿠키 질문좀... [3] ㅇㅇ(175.198) 12.02.21 124 0
304321 3년차입니다 [1] vold갤로그로 이동합니다. 12.02.21 113 0
304320 구석횽이 대2때 분산서버 쉽게 구현했다는거 보고 [2] SODMaster갤로그로 이동합니다. 12.02.21 114 0
304318 [c++] 복룡의 공부일기 1일차 [1] 복룡갤로그로 이동합니다. 12.02.21 68 0
304317 c언어질문 인뎁 [6] (211.200) 12.02.21 71 0
304316 꾀된 정보책을 심심해서보았다 복룡갤로그로 이동합니다. 12.02.21 49 0
304315 어플리케이션플밍공부하거나 할줄아는 고딩횽잇슴 ? [18] (221.138) 12.02.21 132 0
304314 게임 개발하면서 Ynobe갤로그로 이동합니다. 12.02.21 75 0
304313 웹사이트 로그인 툴킷, API 이런 식으로 분리해서 제작하면 안 되나 [5] 나다라마법사(1.237) 12.02.21 95 0
304311 우리나라 카페, 웹사이트등의 폐쇄구조 (푸념) [2] 이모군(175.114) 12.02.21 135 0
304310 생초보에게 자비를 주세요 [2] rnmn갤로그로 이동합니다. 12.02.21 52 0
304309 친구에게 의뢰받아 웹페이지 하나 만드는데 [2] 맙이갤로그로 이동합니다. 12.02.21 65 0
304307 ★맙이★ 형님에게 조공짤 + 프로그래머연봉 사이트 [4] C왕초보(118.221) 12.02.21 212 0
304306 C언어 초고수님들 가르쳐 주세요ㅜㅜ [20] C왕초보(118.221) 12.02.21 165 0
304305 이제 소 안죽이고 소고기 먹는데 [1] 애슐리::그린갤로그로 이동합니다. 12.02.21 82 0
304303 html5 공부할라그러는뎅 [1] (222.239) 12.02.21 98 0
304302 나 얼른 보충역 병특 시켜주세여.. 현기증날라그래여.. [4] ^0^갤로그로 이동합니다. 12.02.21 86 0
304301 형들 vc 2010에서 컴파일할땐 괜찬은데 빌드랑 링크하면 악성코드가 . [3] ㅇㅇ(211.246) 12.02.21 53 0
304298 강민경 존나 이쁘게 나왔네... [4] 쿄스케갤로그로 이동합니다. 12.02.21 168 0
304296 판타지마스터즈 아는사람?? [3] (211.61) 12.02.21 62 0
304295 리눅스에서 무선키보드 먹힌다 [4] 이모군(58.228) 12.02.21 84 0
304292 질문합니다 ``(203.128) 12.02.21 41 0
304290 PE 파일에 대해서 좀 아는 횽 헬프. 간절하다 ㅜㅜ [2] 통맥갤로그로 이동합니다. 12.02.21 90 0
304289 옛날 하니까 생각나는게... [3] SODMaster갤로그로 이동합니다. 12.02.21 72 0
304288 으히히 공부해야지 [11] ㅇㅇㅎ(110.47) 12.02.21 96 1
304287 윈도우즈 프로그래밍에서 shared_ptr 어떻게 쓰냐고 지랄했었었는데. SODMaster갤로그로 이동합니다. 12.02.21 71 0
304286 함수문제하고잇는데 문제점좀 알려주세혀... [10] 코딩...?갤로그로 이동합니다. 12.02.21 96 0
304280 추억의 고전 프로그램.. [20] 쿄스케갤로그로 이동합니다. 12.02.21 207 0
304279 뇌 오버클럭 ㅋㅋㅋ [6] 1(118.220) 12.02.21 127 0
304277 C#에서 비동기 FTP "다운로드" 는 어떻게하남? 궁금이(59.13) 12.02.21 75 0
304276 스크립트로 쓰는건데 뭘 써야될지 모르겠다.. SFCFS갤로그로 이동합니다. 12.02.21 45 0
304275 3D 구조가 3차원 배열로 하는거? [3] 1(118.220) 12.02.21 69 0
304274 vm웨어 핵실드오류... 컴고수님들 도와주십쇼... QWERT.갤로그로 이동합니다. 12.02.21 113 0
304273 횽들 웹소켓 이용해서 채팅사이트 만들고있는데 방 여러개 만드려면 ㅁㄴㅇㄹ(175.210) 12.02.21 79 0
304271 언어가 통일되면 지금보다 좋아질까 나빠질까. [4] ㅇㅇㅎ(110.47) 12.02.21 97 0
304270 yes24는 택배아저씨가 맨날 똑같네. [3] ㅇㅇㅎ(110.47) 12.02.21 97 0
304267 모바일 디씨뷰어에 광고 플랫폼 달아놓으면 유식대장한테 고소먹음? [4] 공돌이대장갤로그로 이동합니다. 12.02.21 76 0
304266 어제 하드웨어 전문가들이랑 우연찮게 술자리가 있었는데... [1] 이문동쮸쮸바갤로그로 이동합니다. 12.02.21 139 0
304260 이노래 아는 사람 있나 ㅎㅎ [3] 쿄스케갤로그로 이동합니다. 12.02.21 47 0
304259 걸리는 이유좀 알려주세요 [2] aos(121.139) 12.02.21 73 0
304258 마이플랫폼때문에 투비에 질문했는데 SFCFS갤로그로 이동합니다. 12.02.21 50 0
304257 하나만 질문할게요(비베) [1] aos(121.139) 12.02.21 54 0
304256 나 연봉 1400이라도 받아씅면 좋겠다 [5] 1(118.220) 12.02.21 148 0
304255 데이터 관리는 a-z 24진법 0-9를 이용한 10진법이 있다 [2] 1(118.220) 12.02.21 61 0
304254 16진수을10진수로바꾸는거문제 [3] ㅇㅇ갤로그로 이동합니다. 12.02.21 75 0
304253 template metaprogramming을 쓰면 될까 [1] 나다라마법사(114.205) 12.02.21 43 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2