디시인사이드 갤러리

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

갤러리 본문 영역

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

생각놀이갤로그로 이동합니다. 2012.02.18 14:52:25
조회 569 추천 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 - -
이슈 [디시人터뷰] 충무로가 주목하는 신예, '세계의 주인' 서수빈 운영자 25/11/24 - -
AD 대학생 필수템! What's in my Bag 운영자 25/11/21 - -
303910 구조체배열에 비트맵핸들저장하믄안되? [3] CHALLENGER갤로그로 이동합니다. 12.02.19 64 0
303909 ㅇㅇ 형은 봅니다. 좋은아버지갤로그로 이동합니다. 12.02.19 47 0
303908 진지하게 한번 썰을 풀어봅니다. 관심 좀 가져 주시면 고맙겠습니다. [1] ㅇㅇ(121.177) 12.02.19 82 0
303905 이거 이렇게 짜면되나요 ? [4] dd(211.117) 12.02.19 50 0
303904 형들 나 내일 회사 합격 발표 나오는데 [4] 막장갤신학생갤로그로 이동합니다. 12.02.19 99 0
303903 안녕은 영원한 헤어짐은 아니겠지요~ [1] ㅋㄱ(183.96) 12.02.19 43 0
303901 형들 c언어 커맨드라인말고 윈도우창으로 표시할려면 어쩨야돼? [3] 래댁갤로그로 이동합니다. 12.02.19 69 0
303900 Press any key to continue가 안 나와요ㅠㅠ [10] 엔터(116.33) 12.02.19 287 0
303899 횽님들 혹시 내 위치를 디지털값으로 알아내는 방법 알고있나요? [24] (110.15) 12.02.19 163 0
303898 페고 떼지형 은 봅니다.2 [8] 좋은아버지갤로그로 이동합니다. 12.02.19 199 0
303897 형들의 도움이 필요합니다 ㅇㄹ(110.9) 12.02.19 28 0
303896 컴터 포맷해야 하는데.. [1] ☎v2.0™갤로그로 이동합니다. 12.02.19 51 0
303895 형들아 내가 마인크 플러그인이 [2] 12345(180.224) 12.02.19 59 0
303894 페고 떼지형 은 봅니다. [6] 좋은아버지갤로그로 이동합니다. 12.02.19 120 0
303893 회사가서 맞짱깐거 [5] 개심심(121.140) 12.02.19 194 0
303892 히밤 망한듯 ㅜㅜ gg(211.117) 12.02.19 43 0
303890 내가 날린 플렉스 파라미터 [4] 좋은아버지갤로그로 이동합니다. 12.02.19 113 0
303889 형들아 별찍기 이렇게하면 싸대기맞음? [2] gg(211.117) 12.02.19 130 0
303887 정보처리기사 2주 남았다.. [1] 공돌이대장갤로그로 이동합니다. 12.02.19 68 0
303886 나 원격좀 해주면 안되까? [8] 좋은아버지갤로그로 이동합니다. 12.02.19 141 0
303884 정보처리 자격증 준비하는데 질문좀..ㅎ [5] 124(211.61) 12.02.19 102 0
303883 어휴, 이 잉여인간아.... [2] 땡칠도사갤로그로 이동합니다. 12.02.19 103 0
303882 블래스터 웜 걸렸는데.. 좀 도와달랑께 ㅜㅜ 도와줍셔(112.149) 12.02.19 74 0
303881 Objective C 질문좀 받아주세요. copy 에 관한거. [5] 통맥갤로그로 이동합니다. 12.02.19 64 0
303880 능력자들은 기계코드를 눈으로 보고 해석가능할까?? [6] (211.61) 12.02.19 126 0
303879 몇일 전에 소프트웨어 산업에 대한 다큐 본사람?? 1234(110.11) 12.02.19 84 0
303877 와 드디어 개발환경 다구축했다. [2] ㅇㅇㅎ(110.47) 12.02.19 86 0
303875 쳇 내 함수포인터에는 관심도 안 주고 [5] 나다라마법사(221.142) 12.02.19 56 0
303874 프갤에도 찌질이 한마리가 돌아다닐줄이야 [6] 미ㅏ(116.125) 12.02.19 107 0
303871 덕짤로 정화하자 [1] 나다라마법사(221.142) 12.02.19 58 0
303870 어제 물어봤는데 플렉스 + 서블릭 하고 있어 .. 젠장 [5] 좋은아버지갤로그로 이동합니다. 12.02.19 96 0
303866 덕짤싸긔 땡칠도사갤로그로 이동합니다. 12.02.19 56 0
303864 SIS 1급 정도면 취직시 토익 700정도 스펙은 될까?? [2] (211.61) 12.02.19 124 0
303862 와 이거 신기하다 [4] 나다라마법사(221.142) 12.02.19 75 0
303861 서버컴 x-window 질문점 [9] 리눅스늅늅(119.205) 12.02.19 64 0
303859 유기농 점심이 무료입니다.직원님. [4] 때릴꺼야?(116.40) 12.02.19 104 0
303858 회사에 여자개발자 신입이 들어왔음.. [5] ㄴㅇㅀ(221.138) 12.02.19 282 0
303857 영어공부 [6] ㅇㅇ(119.71) 12.02.19 77 0
303856 C언어 구조체중에서 이거 왜 안되나요 [10] 12(59.12) 12.02.19 132 0
303855 고닉은 세탁 불가한 2012년 1월 잉여력 랭킹 [7] dot(125.128) 12.02.19 151 0
303854 다시 리눅스 깔까 ㅡㅡ) [2] 땡칠도사갤로그로 이동합니다. 12.02.19 92 0
303852 Delete 가 안되는데 좀 봐줘 [7] Delete(14.36) 12.02.19 66 0
303851 내 문제는 이거 같다 [3] 공학적닭튀김갤로그로 이동합니다. 12.02.19 58 0
303849 objective c 공부 - protocol [4] 통맥갤로그로 이동합니다. 12.02.19 64 0
303847 입갤과 동시에 퇴갤 [2] ㅇㅇㅎ(110.47) 12.02.19 48 0
303846 프로그래밍을 공부하다가 3개의 벽을 만나게 되었는데... [15] 바보플머(218.155) 12.02.19 252 3
303844 바보플머 영어강좌2 [1] 바보플머(218.155) 12.02.19 94 0
303841 objective c 공부 - selector [5] 통맥갤로그로 이동합니다. 12.02.19 84 0
303840 php에서 templete언더바 라는거 쓸려고하는데 처음에 어떻게 깔아? [1] 형들(222.107) 12.02.19 81 0
303839 콘솔기반게임 병신..애자.. [3] 모미지갤로그로 이동합니다. 12.02.19 136 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2