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 도 성능을 높이기 위한 도구로 사용하기도 하나
빅분기 시험은 그런 상황이 아닙니다 🙂 편안하게 아무 숫자로 사용해 주세요!
뒤로가기 버튼 같은 것이 있나요?
0
28
1
강의 연장 문의
0
32
1
출력값 질문
0
31
2
수업노트가 어디에 있나요?
0
29
1
실기시험 제출관련
0
160
2
6.20 작업형 2 과적합
0
169
3
코딩팡 장업형2 베이스 라인 인코딩 종류 질문
0
52
2
로지스틱회귀, 회귀
0
52
2
회귀 문제를 풀때 질문입니다.
0
59
1
불균형 처리 후 성능이 더 낮아졌다면,
0
66
2
실기 체험 제2유형 에러 문의
0
66
1
LIGHTGBM 으로 하면 pred값이 소수점 6자리까지 나오는게 맞나요
0
52
2
3번문제 등분산 가정
0
50
2
작업형3 target 형 변환 질문
0
38
2
[작업형1] 연습문제 섹션1 ~ 10 의 section4
0
40
3
원핫인코딩과 레이블 인코딩에서 concat
0
62
2
제2유형 질문입니다.
0
49
2
C()
0
44
2
작업형 2에서 strafity 적용 유무
0
53
2
수강 기간 연장 가능 여부 문의드립니다.
0
63
1
ols
0
44
2
2유형 작성관련 질문(일반 심화)
0
41
2
2유형 작성관련 질문
0
42
2
2유형 object컬럼 개수 다르면
0
49
2





