Last active
          May 25, 2020 12:48 
        
      - 
      
- 
        Save johnolafenwa/2a0813ce311b2431bb494c04a430e9b5 to your computer and use it in GitHub Desktop. 
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | # Import needed packages | |
| import torch | |
| import torch.nn as nn | |
| from torchvision.transforms import transforms | |
| import matplotlib.pyplot as plt | |
| import numpy as np | |
| from torch.autograd import Variable | |
| from torchvision.models import squeezenet1_1 | |
| import torch.functional as F | |
| import requests | |
| import shutil | |
| from io import open | |
| import os | |
| from PIL import Image | |
| import json | |
| """ Instantiate model, this downloads tje 4.7 mb squzzene the first time it is called. | |
| To use with your own model, re-define your trained networks ad load weights as below | |
| checkpoint = torch.load("pathtosavemodel") | |
| model = SimpleNet(num_classes=10) | |
| model.load_state_dict(checkpoint) | |
| model.eval() | |
| """ | |
| model = squeezenet1_1(pretrained=True) | |
| model.eval() | |
| def predict_image(image_path): | |
| print("Prediction in progress") | |
| image = Image.open(image_path) | |
| # Define transformations for the image, should (note that imagenet models are trained with image size 224) | |
| transformation = transforms.Compose([ | |
| transforms.CenterCrop(224), | |
| transforms.ToTensor(), | |
| transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5)) | |
| ]) | |
| # Preprocess the image | |
| image_tensor = transformation(image).float() | |
| # Add an extra batch dimension since pytorch treats all images as batches | |
| image_tensor = image_tensor.unsqueeze_(0) | |
| if torch.cuda.is_available(): | |
| image_tensor.cuda() | |
| # Turn the input into a Variable | |
| input = Variable(image_tensor) | |
| # Predict the class of the image | |
| output = model(input) | |
| index = output.data.numpy().argmax() | |
| return index | |
| if __name__ == "__main__": | |
| imagefile = "image.png" | |
| imagepath = os.path.join(os.getcwd(), imagefile) | |
| # Donwload image if it doesn't exist | |
| if not os.path.exists(imagepath): | |
| data = requests.get( | |
| "https://github.com/OlafenwaMoses/ImageAI/raw/master/images/3.jpg", stream=True) | |
| with open(imagepath, "wb") as file: | |
| shutil.copyfileobj(data.raw, file) | |
| del data | |
| index_file = "class_index_map.json" | |
| indexpath = os.path.join(os.getcwd(), index_file) | |
| # Donwload class index if it doesn't exist | |
| if not os.path.exists(indexpath): | |
| data = requests.get('https://github.com/OlafenwaMoses/ImageAI/raw/master/imagenet_class_index.json') | |
| with open(indexpath, "w", encoding="utf-8") as file: | |
| file.write(data.text) | |
| class_map = json.load(open(indexpath)) | |
| # run prediction function annd obtain prediccted class index | |
| index = predict_image(imagepath) | |
| prediction = class_map[str(index)][1] | |
| print("Predicted Class ", prediction) | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment