모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    프로그래머님의
    개인페이지입니다
    가입 : 07-05-23
    방문 : 549회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_16277
    작성자 : 프로그래머
    추천 : 2
    조회수 : 1658
    IP : 210.114.***.21
    댓글 : 3개
    등록시간 : 2016/03/18 22:42:28
    http://todayhumor.com/?programmer_16277 모바일
    [뻘글 주의] 알파고로 보는 프로그래밍 이야기
    옵션
    • 창작글
    안녕하세요.

    이번에 알파고가 많이 이야기가 되면서 AI 알고리즘들에 대해 얘기가 많아 뻘글 하나 작성해봅니다.

    기존에 바둑 AI 프로그램들 뿐만 아니라 이번 알파고에서도 사용되고 있는 몬테 카를로 (Monte Carlo) 라는 녀석에 대해 한번 알아볼까 합니다. 

    어떤 확률에 기반한 문제가 있을 경우, 이를 해결하기 위해 확률 모델이라는 것을 설계를 하고 문제를 해결합니다. 확률 모델을 설계 할 때 고려되어야 할 사항이 모델을 설계할때 들어갈 변수들 간의 관계가 확실하여 예측을 정확하게 할 수 있어 해를 찾을 수 있는 경우가 있는 반면에 변수간의 관계가 불명확하여 해를 찾기 힘들어 해에 근접한 수를 찾는 경우가 있습니다.

    예를들어 바둑의 경우, 내가 어떤 수를 놓으려고 할 때, 다음 상대방의 수에 따라 그 다음 자신의 수를 계산하는 방식이기 때문에 위의 확률 모델 종류의 후자라고 할 수 있습니다. 

    보통 후자의 경우, 수치적 난수를 이용하여 시뮬레이션을 통해 특정 수에서 수렴이 되는 수를 찾는 방식을 사용합니다. 이런 확률 모델의 시뮬레이션에서 일반적으로 사용되는 방식이 몬테 카를로 시뮬레이션 입니다.

    몬테 카를로 방식을 이용하여 원주율 (파이)를 구하는 예를 들어 봄으로써 몬테 카를로의 동작 원리를 이해해보도록 하겠습니다. XD

    우리가 처음에 원주율을 구하는 방식을 배울 때 원 지름에 대한 원의 둘레의 길이로 배웁니다. 하지만 여기서는 몬테카를로를 이용하여 확률적으로 원주율을 구하려고 합니다.

    다음과 같이 한 변의 길이가 1인 정사각형과 그 안에 반지름이 0.5인 원이 있다고 가정합니다.

    example.png


    정사각형의 넓이 = 1 * 1 = 1
    원 넓이 = (1 / 2) * (1 / 2) * 원주율 = 원주율 / 4

    원 넓이 / 정사각형 넓이 = (원주율 / 4) / 1

    따라서, 원주율 = (원 넓이 * 4) / 정사각형 넓이 가 됩니다.

    우리가 하려고 하는것은 이 안에 점을 무작위 하게 막 찍습니다. 중요한것은 무작위성의 높을 수록 연산 결과를 더욱 정확해 집니다. :D

    확률적인 방식에 의해 찍인 원 안에 있는 점의 수와 정사각형 안에 있는 점의 수 (이는 전체 점 의 수와 같습니다) 로 위의 원주율을 다음과 같이 계산할 수 있습니다.

    원주율 = (원 넓이 * 4) / 정사각형 넓이  (원 안의 점의 수 * 4) / 정사각형 안의 점의 수

    아래는 python으로 만든 몬테 카를로 기법을 이용한 원주율 계산 시뮬레이션 코드 입니다.

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    import random
     
    radius         = 1 / 2
    cnt_circle     = 0
    cnt_square     = 0
     
    idx          = 0
    cnt_iter     = 10000000
     
    while idx < cnt_iter:
        rnd_x = random.random()
        rnd_y = random.random()
     
        if (rnd_x - radius)**2 + (rnd_y - radius)**2 < (radius*2)**2:
            cnt_circle += 1
     
        cnt_square += 1
        idx += 1
     
    print "The circle count is : %d" % (cnt_circle)
    print "The square count is : %d" % (cnt_square)
    print "The ratio of (4 * circle) / square = pie : %f" % ( (4.0 *cnt_circle) / cnt_square )
    cs

    결과는 다음과 같습니다.

           100개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 2.920000
         1000개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 3.176000
       10000개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 3.152800
      100000개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 3.136080
     1000000개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 3.141328
    10000000개의 무작위한 점을 찍는 경우, The ratio of (4 * circle) / square = pie : 3.141556

    짜잔! 이런식으로 확률적인 방법을 통해 원주율을 계산을 할 수 있습니다.

    더욱 정확히 계산을 원한다면 특정 소수점 밑으로 수렴될때까지 반복을 더 하시면 됩니다. 위에서도 썻지만 결과는 랜덤성에 굉장히 의존을 하고 있기 때문에 좋은 랜덤 함수를 사용해야 합니다 :)

    여기까지 몬테 카를로 기법을 이용하여 확률적으로 원주율을 계산하는 방법을 알아봣습니다. 

    추가적으로 제가 예전에 해킹 대회 문제로 풀었던 것 중에 몬테 카를로 시뮬레이션을 사용했던 적이 있었는데, 그 때의 문제는 블랙잭 이였습니다.

    "I'm playing heads up blackjack. I'm dealt Ace-2 and the dealer has 3 showing. What's the probably of winning if: 1) I stand or 2) I kept playing." 

    이라는 문제였는데, 블랙잭을 할 때 제 손패가 Ace와 2를 갖고 있고 딜러가 3이 펼쳐져 있고 한장은 안보이는 게임일 때 내가 바로 stop 할 경우 이길 확률과 계속 패를 받는 경우 이길 확률을 계산하여 어떤 전략이 더 이길 확률이 높은지 찾는 문제였습니다.

    이 경우에도 몬테 카를로 기법을 사용하여 해결 했는데, 관련 내용과 소스 코드는 제 블로그에 올려 두었으니 관심 있으신분은 한번 보시면 좋을것 같습니다. ( http://hackability.kr/entry/2015TrendMicroCTF-Programming-500-BlackJack )

    즐거운 주말 되세요 ^^

    이 게시물을 추천한 분들의 목록입니다.
    [1] 2016/03/19 00:06:31  118.37.***.148  kosi  439167
    [2] 2016/03/19 23:42:08  1.240.***.215  Jethro  518808
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    18
    [에스파] 닝닝 해킹팀에 대한 개인적인 고찰 [1] 창작글 프로그래머 21/08/18 02:35 225 4
    17
    제시 MV 눈누난나 해외 반응에 대해 느낀점 창작글 프로그래머 20/08/05 13:21 2062 8
    16
    모모링의 "오빠 나 오늘 바뀐거 없어?" 에 대한 두부의 대응 [11] 프로그래머 20/03/19 14:02 503 9
    15
    밑에 웹에서 그래프 그리기 관련해서 글 남깁니다. [5] 프로그래머 16/05/18 16:58 60 2
    14
    하악..시즌하코 71단 클리어 프로그래머 16/03/25 12:07 71 3
    13
    밑에 .js 파일 악성코드 탐지 관련해서 글 하나 작성합니다. [5] 창작글 프로그래머 16/03/22 22:55 26 2
    [뻘글 주의] 알파고로 보는 프로그래밍 이야기 [3] 창작글 프로그래머 16/03/18 22:42 45 2
    11
    [베노스한글 자막] GTA 5 영상. 숨넘어 가는줄 ㅋㅋㅋㅋㅋㅋㅋㅋ [1] 프로그래머 15/12/11 05:16 207 3
    10
    // It always returns TRUE [4] 프로그래머 15/11/13 18:09 37 5
    9
    이야 신난다 버그다 !! ^0^ [2] 프로그래머 15/10/08 12:48 55 2
    8
    밑에 작성했던 테스트 뻘글 관련된 글 입니다. 창작글 프로그래머 15/07/20 11:57 38 1
    7
    심심해서 올리는 누구든지 테스트 가능한 재미진 뻘글 ㅎㅎ [8] 창작글 프로그래머 15/07/18 02:57 48 0
    6
    헐... 이게 무슨 게시판이죠... [1] 프로그래머 14/01/15 06:22 67 0
    5
    한국바둑 역사상 초유의 사건 프로그래머 13/07/21 00:59 36 1
    4
    친구 초대로 새로 키우시는 분들을 위한 간단한 팁 [2] 프로그래머 09/07/10 10:24 232 7
    3
    달라란에 어여쁜 블엘분이 계셔서 인사를 했더니 ^^ [4] 프로그래머 09/05/16 20:47 218 1
    2
    드디어 와우 게시판도 생겻군요 ^^ [1] 프로그래머 09/04/18 03:54 54 0
    1
    오유 스포츠 게시판 아이콘 그냥 끄적 [1] 프로그래머 08/08/24 13:59 134 4
    [1]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈