강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

김라의님의 프로필 이미지
김라의

작성한 질문수

[퇴근후딴짓] 빅데이터 분석기사 실기 (작업형1,2,3)

4회 기출 유형(작업형2)

이해가 가지 않는 것

해결된 질문

작성

·

44

·

수정됨

0

데이터프레임을 만들때 '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

퇴근후딴짓님의 프로필 이미지
퇴근후딴짓
지식공유자

target <- train 데이터 실제 값 (주어진 값)

pred <- test 데이터 예측한 값

작업형 2는 test 데이터 예측 값을 제출해요 🙂

 

0

안녕하세요, 인프런 AI 인턴입니다. 김라의님이 질문하신 데이터프레임 구성에 대한 부분을 이해하는 데 도움이 되시도록 설명드리겠습니다.

김라의님이 제공해주신 코드는 다음과 같습니다:

target = train.pop('Segmentation')  
test_ID = test.pop('ID')  
submit = pd.DataFrame({  
    'ID': test_ID,  
    'Segmentation': pred  
})  
submit  

여기서 중요한 부분은 ‘Segmentation’ 이라는 컬럼에 어떻게 값을 할당할 것인지입니다.

  1. target = train.pop('Segmentation'): 이 라인은 train 데이터프레임에서 ‘Segmentation’이라는 컬럼을 제거하고, 그 값을 target 변수에 저장하고 있습니다. 이 방식은 모델을 학습할 때 사용할 정답 데이터(라벨)를 분리하기 위한 일반적인 방법입니다.

  2. submit = pd.DataFrame({'ID': test_ID, 'Segmentation': pred}): 이 라인은 최종적으로 모델이 예측한 값을 데이터프레임 형태로 저장하는 역할을 합니다. 여기서 ‘Segmentation’에 pred를 사용하는 이유는, predtest 데이터에 대한 예측 결과를 포함하고 있기 때문입니다.

결국, train 데이터를 학습 시 이용한 뒤 예측 값을 pred에 담아 submit 데이터를 구성하는데 활용되고 있는 것입니다. 만약 submittarget을 사용한다면 이는 모델의 예측 결과가 아닌 학습 데이터의 라벨값과 동일하게 되어버리므로 예상된 출력을 얻을 수 없습니다.

참고하면 좋을 유사 질문 링크:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김라의님의 프로필 이미지
김라의

작성한 질문수

질문하기