우노
[ML] Logistic Regression(로지스틱 회귀)이란? 본문
이진 분류(Binary Classification)
이진 분류란, 문제에 대한 정답을 두 가지 답 중 하나로 분류하는 것을 의미한다.
- 예를 들어, 문제에 대한 정답이 0 과 1 중 하나라면,
- 해당 문제에 대한 정답이 1 일 확률이 출력되고,
- 해당 확률이 0.5 이상이면 1 로 판단한다.
그렇다면, 이진 분류 문제는 선형 회귀(Linear Regression)로 해결 할 수 있을까?
선형 회귀는 아래 그림과 같이, Outlier(이상치)에 약하기 때문에 분류 문제에 잘 동작하지 않는다.
따라서, 이러한 이진 분류 문제를 해결하기 위한 회귀 방법 중 하나가, 로지스틱 회귀(Logistic Regression)이다.
로지스틱 회귀(Logistic Regression)
가설(Hypothesis)
- 선형 회귀(Linear Regression)에서는 가설(H(x))로 직선(Wx+b)을 사용한다.
- 하지만, 직선은 이상치를 분류하지 못한다.
- 또한, 우리가 원하는 결과값은 0 과 1 사이의 값이지만, 직선으로 예측값을 추출하면, 보통 0 보다 작거나 1 보다 크기 때문이다.
- 따라서, 로지스틱 회귀(Logistic Regression) 에서는, 가설로 시그모이드(sigmoid) 함수를 사용한다.
시그모이드(Sigmoid) 함수
- 시그모이드 함수를 사용한다면,
- x의 값이 작을 때의 예측값은 1/(1+무한대) 으로 0 에 수렴할 것이며,
- x의 값이 클 때의 예측값은 1/(1+0) 으로 1 에 수렴할 것이다.
- 따라서, 예측 값을 0 과 1 사이의 값으로 추출할 수 있게 된다.
비용 함수(cost function)
선형회귀(Linear Regression)에서는 직선을 가설로 사용하고, mse(mean square error)를 비용 함수로 사용한다.
하지만, 로지스틱 회귀(Logistic Regression)에서는 가설로 시그모이드(Sigmoid) 함수를 사용하기 때문에, mse 로는 비용 함수를 구하기 어렵다.
만약, 가설로 시그모이드(Sigmoid) 함수를 사용하고, 비용 함수로 mse 를 사용한다면 아래와 같은 결과가 나타날 것이다.
위 그림처럼, 평야가 많아지기 때문에, 아무리 학습을 많이해도, mse 를 사용해 구한 cost 함수에서는 gradient descent 알고리즘이 제대로 동작하지 않게 된다.
이를 해결하기 위해, Logistic Regression 에서는 비용함수로 Binary Cross Entropy 를 사용한다.
Binary Cross Entropy
H(x) 는 시그모이드 함수로부터 나온 0 과 1 사이의 노드 예측값이다.
Binary Cross Entropy 는 cost 를 계산할 때, 노드의 실제 값에 따라 다른 방식으로 오차를 구한다.
- n 은 분류 노드 개수를 의미한다.
- 노드가 1개 일 땐, 단일 이진 분류
- 노드가 여러 개 일 땐, 멀티 이진 분류이다.
아래 그림은 실제 값과 예측값에 따른 비용함수이다.
- 실제 값(y)이 1 일 때, 손실은 -log(H(x)) 로 계산된다.
- -log(H(x))가 작아지기 위해선, log(H(x))값이 커져야하기 때문에, H(x) 값이 커져야한다.
- H(x)가 1일 때 log(H(x))는 0이며, 0일 때 log(H(x))는 -무한대이기 때문이다.
- 따라서, 실제 값(y)이 1일 땐, H(x)가 1이 되도록 진행된다.
- -log(H(x))가 작아지기 위해선, log(H(x))값이 커져야하기 때문에, H(x) 값이 커져야한다.
- 실제 값(y)이 0 일 때, 손실은 -log(1-H(x)) 로 계산된다.
- -log(1-H(x))가 작아지기 위해선, log(1-H(x))값이 커져야하기 때문에, H(x) 값이 작아져야한다.
- H(x)가 1일 때 log(1-H(x))는 -무한대이며, 0일 때 log(1-H(x))는 0이기 때문이다.
- 따라서, 실제 값(y)이 0일 땐, H(x)가 0이 되도록 진행된다.
- -log(1-H(x))가 작아지기 위해선, log(1-H(x))값이 커져야하기 때문에, H(x) 값이 작아져야한다.
- 실제 값(y)이 1 일 때, 손실은 -log(H(x)) 로 계산된다.
결론
- Linear Regression
- 가설 : 직선
- cost 함수 : Mean Square Error
- Logistic Regression
- 가설 : Sigmoid
- cost 함수 : Binary Cross Entropy
참고
'AI > Machine Learning' 카테고리의 다른 글
[ML] K-평균(K-Means)이란? (0) | 2020.11.02 |
---|---|
[ML] Softmax Regression(소프트맥스 회귀)이란? (0) | 2020.10.08 |
[ML] 랜덤 포레스트(Random Forest)란? (14) | 2020.09.16 |
[ML] SVM (Support Vector Machine) 이란? (0) | 2020.09.12 |
[ML] 기본선형회귀 모델과 NNLS 모델 비교 코드 (0) | 2020.09.07 |