ResNet मॉडल का उपयोग करके वास्तविक समय की भविष्यवाणी

ResNet एक पूर्व-प्रशिक्षित मॉडल है। इसे ImageNet का उपयोग करके प्रशिक्षित किया गया है । ResNet मॉडल वेट पर पहले से प्रशिक्षित ImageNet । इसके निम्नलिखित सिंटैक्स हैं -

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 मॉडल के लिए छवि इनपुट के रूप में उपयोग करने के लिए वैकल्पिक केरस टेंसर को संदर्भित करता है।

  • 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: छवियों को न्यूपी सरणी में परिवर्तित करें

आइए हम अपने इनपुट को बदलते हैं, 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)
   ]
]

यहां, मॉडल ने छवियों को केले के रूप में सही ढंग से भविष्यवाणी की।