ResNet 모델을 사용한 실시간 예측

ResNet 은 사전 훈련 된 모델입니다. ImageNet을 사용하여 훈련 되었습니다 . ImageNet 에서 사전 학습 된 ResNet 모델 가중치 . 다음과 같은 구문이 있습니다.

keras.applications.resnet.ResNet50 (
   include_top = True, 
   weights = 'imagenet', 
   input_tensor = None, 
   input_shape = None, 
   pooling = None, 
   classes = 1000
)

여기,

  • include_top 네트워크 상단의 완전 연결 계층을 나타냅니다.

  • weights ImageNet에 대한 사전 교육을 참조하십시오.

  • input_tensor 모델의 이미지 입력으로 사용할 선택적 Keras 텐서를 참조합니다.

  • input_shape선택적 모양 튜플을 나타냅니다. 이 모델의 기본 입력 크기는 224x224입니다.

  • classes 이미지를 분류하기 위해 선택적 클래스 수를 참조하십시오.

간단한 예제를 작성하여 모델을 이해합시다.

1 단계 : 모듈 가져 오기

아래에 지정된대로 필요한 모듈을로드하겠습니다.

>>> import PIL 
>>> from keras.preprocessing.image import load_img 
>>> from keras.preprocessing.image import img_to_array 
>>> from keras.applications.imagenet_utils import decode_predictions 
>>> import matplotlib.pyplot as plt 
>>> import numpy as np 
>>> from keras.applications.resnet50 import ResNet50 
>>> from keras.applications import resnet50

2 단계 : 입력 선택

입력 이미지를 선택하겠습니다. Lotus 아래 명시된대로-

>>> filename = 'banana.jpg' 
>>> ## load an image in PIL format 
>>> original = load_img(filename, target_size = (224, 224)) 
>>> print('PIL image size',original.size)
PIL image size (224, 224) 
>>> plt.imshow(original) 
<matplotlib.image.AxesImage object at 0x1304756d8> 
>>> plt.show()

여기에 이미지를로드했습니다. (banana.jpg) 그리고 그것을 표시했습니다.

3 단계 : 이미지를 NumPy 배열로 변환

입력을 변환 해 보겠습니다. Banana 예측을 위해 모델에 전달할 수 있도록 NumPy 배열에 넣습니다.

>>> #convert the PIL image to a numpy array 
>>> numpy_image = img_to_array(original) 

>>> plt.imshow(np.uint8(numpy_image)) 
<matplotlib.image.AxesImage object at 0x130475ac8> 

>>> print('numpy array size',numpy_image.shape) 
numpy array size (224, 224, 3) 

>>> # Convert the image / images into batch format 
>>> image_batch = np.expand_dims(numpy_image, axis = 0) 

>>> print('image batch size', image_batch.shape) 
image batch size (1, 224, 224, 3)
>>>

4 단계 : 모델 예측

우리의 입력을 모델에 입력하여 예측을 얻습니다.

>>> prepare the image for the resnet50 model >>> 
>>> processed_image = resnet50.preprocess_input(image_batch.copy()) 

>>> # create resnet model 
>>>resnet_model = resnet50.ResNet50(weights = 'imagenet') 
>>> Downloavding data from https://github.com/fchollet/deep-learning-models/releas
es/download/v0.2/resnet50_weights_tf_dim_ordering_tf_kernels.h5 
102858752/102853048 [==============================] - 33s 0us/step 

>>> # get the predicted probabilities for each class 
>>> predictions = resnet_model.predict(processed_image) 

>>> # convert the probabilities to class labels 
>>> label = decode_predictions(predictions) 
Downloading data from https://storage.googleapis.com/download.tensorflow.org/
data/imagenet_class_index.json 
40960/35363 [==================================] - 0s 0us/step 

>>> print(label)

산출

[
   [
      ('n07753592', 'banana', 0.99229723), 
      ('n03532672', 'hook', 0.0014551596), 
      ('n03970156', 'plunger', 0.0010738898), 
      ('n07753113', 'fig', 0.0009359837) , 
      ('n03109150', 'corkscrew', 0.00028538404)
   ]
]

여기서 모델은 이미지를 바나나로 올바르게 예측했습니다.