일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 머신러닝
- 컴퓨터 비전
- Unsupervised learning
- 로지스틱 회귀
- 백준
- SGD
- 추천 시스템
- Vision
- SVM
- 인공지능
- CPP
- 신경망
- cs231n
- Kaggle
- 그래픽스
- Support Vector Machine
- logistic regression
- 딥러닝
- C++
- neural network
- Regularization
- petal to metal
- 컴퓨터 그래픽스
- recommender system
- OpenGL
- 파이썬
- Computer Vision
- 비용함수
- CNN
- pre-trained
- Today
- Total
kwan's note
online learning , map reducing -온라인 학습, 병렬 학습 본문
online learning , map reducing -온라인 학습, 병렬 학습
kwan's note 2021. 2. 8. 00:09출처: machine learning by andrew ng, stanford cousera lecture
수강일시: 2021.02.07
reminder-by-kwan.tistory.com/110
이번에도 데이터가 많은경우 처리방법에 대해 배워보도록 하겠습니다.
첫번째 주제는 online learning이고 두번째는 map reducing 입니다.
Online learning
online learning은 SGD와 매우 비슷한 방법입니다.
데이터가 실시간으로 계속 주어질때,
예를들어 온라인 쇼핑몰을 운영하는데 추천시스템을 만들고자 한다고 가정해보자.
어떤 소비자가 어떤 상품을 선택할지에 대해 학습하고 선택확률이 높은 아이템을 추천해주고자 할 때
새로운 소비자가 올때마다 새로운 데이터가 쌓이게 된다.
이런 많은 정보가 주어질때 사용하는 방식을 online learning이라고 한다.
따라서 온라인 학습에서는 데이터를 쌓아두지 않고 매 데이터가 들어올때마다 해당 x y에 대해서만 학습하고 버린다.
그럼에도 데이터가 계속 공급되므로 좋은 성능을 보이게 된다.
map reducing
다음으로는 맵 리듀싱에 대해 배워보도록 하겠습니다.
이는 병렬 연산의 방법입니다.
매우 많은 데이터가 있을경우 각 학습을 하나의 컴퓨터에서 전부 처리하는것이 아닌 n개의 컴퓨터로 나누어 처리하고 합치는 개념입니다.
4백만개의 데이터가 있을때 4개의 컴퓨터를 이용하면 각 컴퓨터가 백만개의 데이터를 처리해서 이에대한 tempj값을 얻어내고 이를 평균내서 기울기로 사용하는 방식입니다.
이제는 일반적인 컴퓨터도 여러개의 코어를 가지고 있으므로 한개의 컴퓨터 내에서도 다중코어를 이용해 연산하여 합칠 수 있습니다.
많은 라이브러리들이 이러한 병렬연산을 지원하고 있으므로 이를 이용해서 계산하는것이 데이터가 많은경우 효과적일 것 입니다.
'ML and AI > Machine learning - Andrew Ng' 카테고리의 다른 글
머신러닝 성능을 높이는 방법 (1) | 2021.02.09 |
---|---|
Mini batch gradient descent (0) | 2021.02.07 |
Stochastic gradient descent(SGD) -확률적 경사 하강법 (0) | 2021.02.07 |
Collaborative filtering - 협업 필터링 (0) | 2021.02.07 |
recommendation system - 추천 시스템 (content based) (0) | 2021.02.07 |