인공지능/딥러닝
딥 러닝 : 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)
