인공지능/딥러닝

딥 러닝 : Transfer Learning ( MobileNetV2 )

왕현성 2023. 1. 2. 12:33
728x90
!wget --no-check-certificate \
    https://storage.googleapis.com/mledu-datasets/cats_and_dogs_filtered.zip \
    -O ./cats_and_dogs_filtered.zip

개 vs 고양이 이미지 파일 다운로드 코드

 

import os
import zipfile
import numpy as np
import tensorflow as tf
import matplotlib.pyplot as plt

# 파이썬의 진행상태를 표시해 주는 라이브러리
from tqdm import tqdm_notebook

from tensorflow.keras.preprocessing.image import ImageDataGenerator

%matplotlib inline
tf.__version__

사용할 라이브러리들을 임포트 해줍니다.

 

file = zipfile.ZipFile('/content/cats_and_dogs_filtered.zip')
file.extractall('./')

압축을 풀어주고

train_dir = ('/content/cats_and_dogs_filtered/train')
test_dir = ('/content/cats_and_dogs_filtered/validation')

트레이닝과 테스트 디렉토리 경로 변수로 저장

 

트랜스퍼 러닝은 학습이 잘 된 모델을 가져와서 우리의 문제에 맞게 활용하는 것이므로 학습이 잘 된 모델의 베이스 모델만 가져온다(헤드모델은 빼고)

 

# 우리가 만드려는 모델의 인풋 이미지는 128,128,3으로 한다.
IMG_SHAPE = (128, 128, 3)
base_model = tf.keras.applications.MobileNetV2(input_shape=IMG_SHAPE,include_top=False)
# 우리가 가져온 모델의 베이스모델 부분은
# 이미 1400만 장 이상의 이미지로 학습이 잘 되어 있어서
# 이미지의 특징을 뽑아내는 역할을 하므로
# 우리 데이터로는 학습이 되지 않도록 한다. < = Freezing

base_model.trainable = False
base_model.summary()

이 전에는 model.add() 이런 식으로 헤드 모델을 커스텀 해주었다면

from keras.layers import Flatten,Dense
head_model = base_model.output
head_model = Flatten()(head_model)
head_model=Dense(128,'relu')(head_model)
head_model=Dense(1,'sigmoid')(head_model)

트랜스퍼러닝에서는 위 코드와같이 작성을 해줍니다.

 

이후 베이스모델과 헤드모델을 합치는 코드

from keras.models import Model
model = Model(inputs=base_model.input,outputs = head_model)

컴파일 과정

from keras.optimizers import RMSprop
model.compile( RMSprop(0.0001) , 'binary_crossentropy' , ['accuracy'] )

Data Generators를 만들어 줍니다.

# 실무에서는, 데이터 증강까지 하도록 한다.
train_datagen = ImageDataGenerator(rescale = 1/255.0,width_shift_range=0.2)
test_datagen = ImageDataGenerator(rescale = 1/255.0)
train_generator=train_datagen.flow_from_directory(train_dir,target_size=(128,128),class_mode='binary',
                                  batch_size = 128)
                                 
test_generator = test_datagen.flow_from_directory(test_dir,target_size=(128,128),
                                                  class_mode='binary',
                                                  batch_size=128)

 

학습과 평가 과정

epoch_history = model.fit(train_generator,epochs=5,validation_data=(test_generator))

model.evaluate(test_generator)