일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 자바
- Spring JPA
- CS
- SW Expert Academy
- SECS-II
- C++
- Gem
- MYSQL
- Spotify Api
- programmers
- c
- SECS/GEM
- 프로그래머스
- 스포티파이
- SWEA
- SECS
- Spring
- spring boot
- python
- 비트겟
- regression
- modern c++
- spotify
- 백준
- 파이썬
- Computer Science
- 회원가입
- 회귀
- java
- Baekjoon
Archives
- Today
- Total
비버놀로지
[회귀(Regression)] 회귀 알고리즘 평가 지표- RSS 본문
728x90
회귀 알고리즘 평가 지표- RSS
이번 실습에서는 회귀 알고리즘을 위한 다양한 평가 지표 중 가장 기본적인 Loss Function인 RSS(단순 오차제곱합)을 직접 계산해보고, 결과를 확인해보겠습니다.
실습
- 회귀 알고리즘의 평가 지표 중 단순 오차 제곱합인 RSS(Residual Sum of Squares) 를 계산하여 반환하는 함수 return_RSS()를 완성합니다.
- 정의한 함수들을 이용하여 main() 함수를 완성합니다.
- 실행 버튼을 눌러 계산된 RSS값을 확인합니다.
import matplotlib.pyplot as plt
import numpy as np
from elice_utils import EliceUtils
elice_utils = EliceUtils()
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LinearRegression
# 데이터 X와 y를 생성하고, 학습용 데이터와 테스트용 데이터로 분리하여 반환하는 함수입니다.
def load_data():
np.random.seed(0)
X = 5*np.random.rand(100,1)
y = 3*X + 5*np.random.rand(100,1)
train_X, test_X, train_y, test_y = train_test_split(X,y,test_size=0.3, random_state=0)
return train_X, train_y, test_X, test_y
# 회귀 모델을 불러오고, 불러온 모델을 학습용 데이터에 맞춰 학습시켜 반환하는 함수입니다.
def Linear_Regression(train_X, train_y):
lr = LinearRegression()
lr.fit(train_X,train_y)
return lr
"""
1. RSS(Residual Sum of Squares)를 계산하여
반환하는 함수를 완성합니다.
"""
def return_RSS(test_y, predicted):
RSS = 0
for i in range(len(test_y)) :
RSS += (test_y[i] - predicted[i])**2
return RSS
# 그래프로 시각화합니다.
def plotting_graph(test_X, test_y, predicted):
plt.scatter(test_X,test_y)
plt.plot(test_X, predicted, color='r')
plt.savefig("result.png")
elice_utils.send_image("result.png")
"""
3. 정의한 함수들을 이용하여 main() 함수를 완성합니다.
Step01. 생성한 데이터를
학습용 데이터와 테스트 데이터로
분리하여 반환하는 함수를 호출합니다.
Step02. 학습용 데이터를 바탕으로 학습한 선형 회귀
모델을 반환하는 함수를 호출합니다.
Step03. 학습된 모델을 바탕으로 계산된
테스트 데이터의 예측값을 predicted에
저장합니다.
Step04. 회귀 알고리즘을 평가하기 위한 RSS 값을 RSS에
저장합니다.
"""
def main():
train_X, train_y, test_X, test_y = load_data()
lr = Linear_Regression(train_X, train_y)
predicted = lr.predict(test_X)
RSS = return_RSS(test_y, predicted)
print("> RSS :",RSS)
plotting_graph(test_X, test_y, predicted)
if __name__=="__main__":
main()
728x90
'인공지능 머신러닝' 카테고리의 다른 글
[회귀(Regression)] 회귀 알고리즘 평가 지표- R_squared (0) | 2022.11.06 |
---|---|
[회귀(Regression)] 회귀 알고리즘 평가 지표- MSE, MAE (0) | 2022.11.06 |
[회귀(Regression)] 엘라스틱넷(ElasticNet) 회귀 (0) | 2022.11.06 |
[회귀(Regression)] 릿지(Ridge), 라쏘(Lasso) 회귀 (0) | 2022.11.06 |
[회귀(Regression)] 과적합 방지 기법 - 교차 검증 (0) | 2022.11.06 |
Comments