random_state=0, random_state=123 차이가 발생합니다. 어떤값을 넣어야 하나요? 최적값이 따로 있나요?
0
df = pd.DataFrame({
'f1': [2, 3, 5, 7, 11, 13, 17, 19, 23, 29],
'f2': [30, 28, 26, 24, 22, 20, 18, 16, 14, 12],
'target': ['A', 'A', 'A', 'B', 'B', 'A', 'A', 'A', 'A', 'B']
})
y_train = df.pop('target')
x_tr, x_val, y_tr, y_val = train_test_split(df, y_train, test_size=0.5, random_state=123)
print(x_tr.shape, x_val.shape, y_tr.shape, y_val.shape)
model_rfc = RandomForestClassifier(random_state=42)
model_rfc.fit(x_tr, y_tr)
y_proba_val_rfc = model_rfc.predict_proba(x_val)
print(y_proba_val_rfc)
roc = roc_auc_score(y_val, y_proba_val_rfc[:,1])
print(roc)
(5, 2) (5, 2) (5,) (5,)
[[0.29 0.71]
[0.92 0.08]
[0.7 0.3 ]
[0.74 0.26]
[0.45 0.55]]
1.0
-------------------------------------------------------------------------
df = pd.DataFrame({
'f1': [2, 3, 5, 7, 11, 13, 17, 19, 23, 29],
'f2': [30, 28, 26, 24, 22, 20, 18, 16, 14, 12],
'target': ['A', 'A', 'A', 'B', 'B', 'A', 'A', 'A', 'A', 'B']
})
target = df.pop('target')
X_train, X_val, y_train, y_val = train_test_split(df, target, test_size=0.5, random_state=0)
clf = RandomForestClassifier(random_state=42)
clf.fit(X_train, y_train)
y_pred = clf.predict_proba(X_val)[:,1]
print(y_pred) # 예측값
roc_auc_score(y_val, y_pred) # 정확도 평가
[0.68 0. 0.25 0. 0.26]
np.float64(0.25)
답변 1
0
random_state로 고민하지는 마시죠!!
랜덤적인 요소를 고정적으로 만든다 생각하고 특정 숫자로 고정하시면 됩니다.
컴피티션(대회) 같이 0.001이 중요한 경우 random_state 도 성능을 높이기 위한 도구로 사용하기도 하나
빅분기 시험은 그런 상황이 아닙니다 🙂 편안하게 아무 숫자로 사용해 주세요!
1유형 강의 다 나간 후 어떻게 할까요?
0
14
1
점수차가 많이 나는데 따로 하신게 있으신가요?
0
10
1
작업형1 모의문제 4번에 3)문제 질문
0
21
2
이상치 전처리 작업
0
25
2
평가결과값 문의
0
29
2
시계열 데이터 날짜와 시간 format
0
35
2
평가지표 F1 스코어 질문드립니다.
0
27
2
작업형 2 기출7회분에서
0
38
2
작업형2 모의문제1 (30강)
0
34
2
수강 기간 연장 문의 드립니다.
0
42
2
수강 계획과 관련해 문의 드립니다.
0
30
2
작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?
0
50
2
작업형 1 -연습문제 4-6
0
38
2
작업형 1 유형 부분
0
42
2
작업형 1 (삭제예정, 구 버전)
0
51
2
수강기간 연장 문의드립니다.
0
38
2
2유형 레이블 인코딩 VS 원핫 인코딩
0
37
3
수강기간 연장 문의드립니다.
0
44
2
인덱스 슬라이싱
0
37
2
질문 드립니다.
0
50
2
강의 내용 관련 질문드립니다~
0
46
2
수강 연장 문의
0
63
2
강의자료 일괄 다운로드
0
62
2
수강기간 연장 문의드립니다
0
48
2





