(y_test['income']=='>50K').astype(int) 관련
(y_test['income']=='>50K').astype(int)
로 코딩하면 바로 0 혹은 1의 값으로 바로 변경되던데요.
만약 3개 이상의 target 값이 있을경우 astype(int) 하게되면 0, 1, 2 로 3개가 생기는 걸까요?
답변 2
0
다중분류일 때 타겟은 변경하지 말고 그대로 사용해주세요!
이진분류에서도 문자 그대로 사용 가능합니다.
(y_test['income']=='>50K').astype(int) 는 이진분류이고 타겟을 변경하라는 문제가 있다면 변경 가능합니다. -> 심화 내용으로 어렵다면 패스해 주세요!
0
안녕하세요, 인프런 AI 인턴입니다. 김치현 님의 질문에 대해 답변드리겠습니다.
(y_test['income'] == '>50K').astype(int) 코드는 이진 분류 문제에서 True/False를 각각 1과 0으로 변환하는 코드입니다. 이 경우 y_test['income'] > 50K 인 경우에는 1(참), 그 외의 경우에는 0(거짓)으로 변환됩니다.
하지만 질문에서 말씀하신 것처럼 3개 이상의 target 값을 다루는 경우에는 상황이 조금 달라집니다. astype(int)를 사용한 변환은 기본적으로 이진 조건 평가에만 적합합니다. 즉, 단일 논리 조건의 결과를 정수로 변환할 때 True는 1, False는 0으로 변환할 수 있지만, 세 개 이상의 값을 다루기 위해서는 별도의 로직이 필요합니다.
세 개 이상의 카테고리를 다루고자 할 경우, 예를 들어 ‘소득 수준’이 ‘<50K', '50K-100K', '>100K’ 등의 세 가지 수준으로 나뉜다면, 이를 0, 1, 2로 엔코딩하기 위해서 pd.Categorical이나 LabelEncoder를 사용하시기 바랍니다.
유사한 질문과 관련된 답변을 확인하실 수 있는 URL은 다음과 같습니다:
- y_tr 과 y_train 의 차이점
- 모델링 및 평가(분류) 강의에서
- 학습용/검증용 데이터 구분
이러한 링크에서는 이진분류를 위한 데이터 처리와 여러 값들이 있을 때의 처리에 관한 질문과 답변을 확인하실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
작업형2 카테고리
0
8
1
110강 회귀_8번 문의
0
9
2
XGBRegressor 학습 시 warning 출력
0
13
2
데이터 프레임을 변경해도 되나요?
0
10
2
10회 기출 작업형3 문제 2-1 질문
0
16
2
작업형 2 질문
0
16
2
작업형 2 템플릿 확인 요청
0
13
2
작업형2 인코딩 질문
0
22
2
작업형 3 벼락치기 공부방법 질문
0
31
2
기출 11회 작업형 2_전체 데이터 학습 여부
0
32
2
예측값 결과 소수점 차이
0
28
2
기출 문제와 실전챌린지 연습문제 무엇부터 푸는게 나은가요?
0
35
1
전처리 train() test([ ])
0
23
2
작업형 1 배경지식 질문
0
33
2
옳게 풀은건지 질문드립니다!
0
22
1
roc_auc_score
0
30
2
추가질문 합니다
0
22
2
시험환경 구름
0
21
2
2유형 질문드려요
0
21
2
RandomForest vs lgb
0
30
2
전처리 관련질문
0
29
3
작업형3 기출
0
21
2
유형2에서 데이터분할 생략 가능여부
0
33
2
9회 기출 유형3 질문
0
21
2





