inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

4회 기출 유형(작업형2)의 xgb 에러 관련

해결된 질문

1143

ycann

작성한 질문수 26

0

선생님!! 4회 기출 유형(작업형2)에서 랜덤포레스트와 lgb 는 이상이 없는데, xgb 로 모델링 할 경우에만 에러가 발생하는데, 무슨 문제인가요?

[코딩]

import pandas as pd

train = pd.read_csv('train.csv')

test = pd.read_csv('test.csv')

# print(train.shape, test.shape)

# print(train.head(3))

# print(test.head(3))

# print(train.info())

# print(train.describe())

# print(train.describe(include='object'))

# print(test.describe(include='object'))

# print(train['Segmentation'].value_counts())

# print(train.isnull().sum())

# print(test.isnull().sum())

train = train.drop('ID', axis=1)

test_id = test.pop('ID')

test.head(3)

cols = train.select_dtypes(include='object').columns

print(cols)

from sklearn.preprocessing import LabelEncoder

for col in cols :

le = LabelEncoder()

train[col] = le.fit_transform(train[col])

test[col] = le.transform(test[col])

train.head(3)

from sklearn.model_selection import train_test_split

X_tr, X_val, y_tr, y_val = train_test_split(train.drop('Segmentation', axis=1), train['Segmentation'], test_size=0.1, random_state=2022)

print(X_tr.shape, X_val.shape, y_tr.shape, y_val.shape)

from sklearn.metrics import f1_score

from sklearn.ensemble import RandomForestClassifier

rf = RandomForestClassifier(random_state=2022, max_depth=7, n_estimators=100)

rf.fit(X_tr, y_tr)

pred = rf.predict(X_val)

pred[:10]

f1_score(y_val, pred, average='macro')

from sklearn.metrics import f1_score

# import lightgbm as lgb

# model = lgb.LGBMClassifier(random_state=2022, max_depth=5, n_estimators=800, learning_rate=0.01 )

# model.fit(X_tr, y_tr)

# pred = model.predict(X_val)

# pred[:10]

# f1_score(y_val, pred, average='macro')

from sklearn.metrics import f1_score

from xgboost import XGBClassifier

xgb = XGBClassifier(random_state=2022)

xgb.fit(X_tr, y_tr)

pred = xgb.predict(X_val)

pred[:10]

[에러내용]

ValueError Traceback (most recent call last)

<ipython-input-57-d656863c7bc3> in <cell line: 4>()

2 from xgboost import XGBClassifier

3 xgb = XGBClassifier(random_state=2022)

----> 4 xgb.fit(X_tr, y_tr)

5 pred = xgb.predict(X_val)

6 pred[:10]

1 frames

/usr/local/lib/python3.10/dist-packages/xgboost/sklearn.py in fit(self, X, y, sample_weight, base_margin, eval_set, eval_metric, early_stopping_rounds, verbose, xgb_model, sample_weight_eval_set, base_margin_eval_set, feature_weights, callbacks)

1438 or not (self.classes_ == expected_classes).all()

1439 ):

-> 1440 raise ValueError(

1441 f"Invalid classes inferred from unique values of y. "

1442 f"Expected: {expected_classes}, got {self.classes_}"

ValueError: Invalid classes inferred from unique values of y. Expected: [0 1 2 3], got [1 2 3 4]

python 머신러닝 빅데이터 pandas 빅데이터분석기사

답변 1

0

퇴근후딴짓

우선 xgboost가 너무 예민해요~ 그래서 xgb대신 lightgbm를 추천해요!

y 종류(클래스)가 1234인데

xgb는 0부터 구성되어야 해요. 그러니깐 클래스가 0,1,2,3이 되어야 합니다.

 

1

ycann

예!

lgb를 사용해야 겠네요. ㄱ마사합니다.

평가결과값 문의

0

2

1

시계열 데이터 날짜와 시간 format

0

15

1

평가지표 F1 스코어 질문드립니다.

0

16

2

작업형 2 기출7회분에서

0

32

2

작업형2 모의문제1 (30강)

0

28

2

수강 기간 연장 문의 드립니다.

0

35

2

수강 계획과 관련해 문의 드립니다.

0

26

2

작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?

0

49

2

작업형 1 -연습문제 4-6

0

35

2

작업형 1 유형 부분

0

42

2

작업형 1 (삭제예정, 구 버전)

0

51

2

수강기간 연장 문의드립니다.

0

37

2

2유형 레이블 인코딩 VS 원핫 인코딩

0

37

3

수강기간 연장 문의드립니다.

0

44

2

인덱스 슬라이싱

0

36

2

질문 드립니다.

0

50

2

강의 내용 관련 질문드립니다~

0

46

2

수강 연장 문의

0

63

2

강의자료 일괄 다운로드

0

58

2

수강기간 연장 문의드립니다

0

48

2

list 문제 질문드립니다~

0

38

2

빅분기 실기 12회 재도전

0

63

2

강의 기간 연장 가능여부 검토 요청건

0

51

2

수강기간 연장 문의 드립니다

0

46

2