inflearn logo
강의

講義

知識共有

Python無料講義(活用編7) - 機械学習

K平均 (演習 #2)

K-평균(실습#2) 의 fit, fit_transform 질문입니다.

434

soryong722668

投稿した質問数 5

0

StandardScaler()

KMeans()

객체 생성 후 fit_transform(), fit() 으로 학습데이터 만들기 하는데, 모두 훈련데이터니까...

둘다 fit(), 또는 fit_transform()으로 구분없이 사용해도 되는건가요?

아니면... 구분지어야 하는 이유가 있는건지 궁금합니다.

 

python 머신러닝 anaconda scikit-learn

回答 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.
따숩게님, 질문 주셔서 감사합니다.

StandardScaler()KMeans()와 같은 사이킷런 라이브러리에서 제공하는 메서드를 사용할 때 fitfit_transform의 차이를 이해하는 것이 중요합니다.

fit 메서드는 데이터에 대한 학습만을 수행합니다. 즉, 데이터를 바탕으로 필요한 통계치(예를 들어, 평균과 표준편차 등)를 계산하고 모델을 학습시키는데 사용됩니다.
fit_transform 메서드는 학습을 수행하는 동시에, 학습된 파라미터로 데이터를 변환하는 작업도 거칩니다. 예를 들어, StandardScaler의 경우 학습 데이터를 표준화하는 과정으로, 각 특성의 평균을 0, 표준편차를 1로 만드는 변환을 수행합니다.

KMeans 알고리즘의 경우,
- fit은 클러스터 중심을 계산하고 데이터를 클러스터에 할당하는 과정을 거칩니다.
- fit_transformfit을 수행하고, 추가로 각 데이터 포인트를 클러스터 중심으로부터의 거리로 변환하는 과정을 포함합니다.

따라서 fitfit_transform을 사용할 때에는, 만약 변환된 데이터를 바로 사용하고 싶다면 fit_transform을, 단순히 모델을 학습시키기만 하고 싶다면 fit을 사용하면 됩니다. 다만, fit_transform은 일반적으로 학습 데이터에만 적용하고, 테스트 데이터는 따로 transform 메서드를 통해 변환하는 것이 일반적입니다. 이는 데이터의 정보 누설을 막고 모델의 일반화 능력을 평가하는 데 도움이 되기 때문입니다.

질문에 대한 답이 되었길 바라며, 더 궁금한 점이 있으시면 언제든지 문의해주시기 바랍니다.

시험환경 구름

0

3

1

2유형 질문드려요

0

3

1

RandomForest vs lgb

0

15

1

전처리 관련질문

0

9

2

수강기간즘연장해주세요

0

8

1

작업형3 기출

0

8

1

유형2에서 데이터분할 생략 가능여부

0

16

2

9회 기출 유형3 질문

0

12

1

lgb 기초편

0

8

1

수업자료 문의

0

12

2

괄호 사용

0

12

1

작업형 2 데이터 전처리 질문

0

16

1

11회 기출 유형 작업형1 문제 3-1

0

11

0

7회 3유형 2번문제 질문

0

10

1

예시문제 작업형2 (ver2023) 질문입니다

0

14

1

Data type에 따른 처리

0

12

2

Cursor 실행 문의

1

13

2

데이터 전처리 관련

0

14

2

시험에서 문제 불러오기

0

14

2

머신러닝 - surprise 모듈 설치 오류

0

372

1

K-평균(실습#3) 결과 값이 왜 다르게 나올까요?

0

247

1

다항회귀(실습#2)

0

276

1

선형 회귀

0

410

0

협업(리뷰 기반)필터링#1 질문

0

908

1