이해가 가지 않는 것
데이터프레임을 만들때 'ID'는 test_id로 pop 했기 때문에 'ID':test_ID가 되는게 이해가 되는데 그러면 'Segmentation'은 :pred가 아닌 target이 되어야 하는것 아닌가요?
target = train.pop('Segmentation')
test_ID = test.pop('ID')
# 예측 결과 -> 데이터 프레임
submit = pd.DataFrame({
'ID': test_ID,
'Segmentation':pred
})
submit
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. 김라의님이 질문하신 데이터프레임 구성에 대한 부분을 이해하는 데 도움이 되시도록 설명드리겠습니다.
김라의님이 제공해주신 코드는 다음과 같습니다:
target = train.pop('Segmentation')
test_ID = test.pop('ID')
submit = pd.DataFrame({
'ID': test_ID,
'Segmentation': pred
})
submit
여기서 중요한 부분은 ‘Segmentation’ 이라는 컬럼에 어떻게 값을 할당할 것인지입니다.
target = train.pop('Segmentation'): 이 라인은train데이터프레임에서 ‘Segmentation’이라는 컬럼을 제거하고, 그 값을target변수에 저장하고 있습니다. 이 방식은 모델을 학습할 때 사용할 정답 데이터(라벨)를 분리하기 위한 일반적인 방법입니다.submit = pd.DataFrame({'ID': test_ID, 'Segmentation': pred}): 이 라인은 최종적으로 모델이 예측한 값을 데이터프레임 형태로 저장하는 역할을 합니다. 여기서 ‘Segmentation’에pred를 사용하는 이유는,pred가test데이터에 대한 예측 결과를 포함하고 있기 때문입니다.
결국, train 데이터를 학습 시 이용한 뒤 예측 값을 pred에 담아 submit 데이터를 구성하는데 활용되고 있는 것입니다. 만약 submit에 target을 사용한다면 이는 모델의 예측 결과가 아닌 학습 데이터의 라벨값과 동일하게 되어버리므로 예상된 출력을 얻을 수 없습니다.
참고하면 좋을 유사 질문 링크:
- 작업형2 모의문제1 에서 오류가 발생하는데 원인을 모르겠습니다 - 데이터 예측 값에 대한 이해를 돕는 게시물입니다.
- 기출4회 작업형 2 오류(샘플수) - 데이터프레임 구성에 대한 설명과 유사한 사례입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
빅이시 작업형2 기초 - 케이스 1~3 관련 문의
0
5
1
데이터프레임 슬라이싱 인덱싱 질문2
0
11
1
단일표본검정, 샤피로검정, 윌콕슨검정
0
20
2
강의자료 다운로드 여부
0
18
1
문제에 첨부된 예시와 실제 출력된 샘플 비교
0
15
2
원핫 인코딩 관련
0
26
2
타겟 분리
0
22
2
Id 삭제
0
25
2
roc_auc_score 질문: 작업형2 모의문제3 09분 48초
0
23
2
원핫인코딩 코드 질문
0
22
2
map 함수 사용 필수적인가요
0
31
2
수강 기한 연장 문의드립니다.
0
39
2
34강 평가지표
0
32
2
103강 작업2형 전처리(레이블인코딩 부분) 오류
0
23
3
작업형1_section14 문의
0
20
2
작업형1_연습문제 7번 관련입니다.
0
24
2
데이터 프레임 슬라이싱 혹은 데이터 선택하기가 어렵습니다.
0
22
2
크로스 밸리데이션 질문
0
25
2
로지스틱 회귀분석 질문
0
26
2
수치형 데이터만 선택하여 푸는 경우에 오답확률이 높아질까요?
0
31
2
2유형 object 컬럼 인코딩 관련 질문
0
44
2
하이퍼파라미터 변수
0
35
2
52강 이원분산분석
0
32
2
실제시험환경에서 작업형1,2,3의 문제풀이 순서
0
39
2





