GithubHelp home page GithubHelp logo

vinayakarannil / deeplearning_image_similarity Goto Github PK

View Code? Open in Web Editor NEW
105.0 7.0 35.0 298 KB

Deep learning based image similarity search for product recommendations

Python 54.75% HTML 45.25%
image-similarity recommendation-engine deep-learning tensorflow

deeplearning_image_similarity's Introduction

Image similarity search using deep learning

This project demonstrates, how we can make use of deep learning to do state-of-the-art image similarity search. I have used tensorflow and some publicly available datasets.

Results

alt text alt text alt text

How to run

  1. Download imagenet folder, extraxt and keep it in server directory
  2. Download datasets for footwares, apparels keep them inside a directory under upload folder. Final folder strcture will be as below
      root folder  
      │
      └───lib
      │   
      └───server
      |   │───rest-server.py
      |   │───imagenet
      |   │───static
      |   │───templates
      |   │───uploads
      |        │────dogs_and_cats
      |              │────shoes
      |              │────sandals
      |              │────slippers
      |              │────boots
      |              │────apparels
  1. Run image vectorizer which passes each data through an inception-v3 model and collects the bottleneck layer vectors and stores in disc. Edit dataset paths accordingly indide the image_vectorizer.py
  python server/image_vectorizer.py 

This will generate two files namely, image_list.pickle and saved_features.txt. Keep them inside lib folder where search.py script is available.

  1. Start the server by running rest-server.py. This project uses flask based REST implementation for UI
  python server/rest-server.py 
  1. Once the server starts up, access the url 127.0.0.1:5000 to get the UI. Now upload any file and see 9 similar images. You can change the value of K from 9 to any values, but dont foreget to update the html file accordingly for displaying.

One interesting application of this project is a recommendation engine based on image features.Here is an example of similar project of mine. Here instead of a web UI i have used an android UI. Once the user clicks a product image, the image will go to the server and k-number of similar product images can be displayed on UI as product recommendations. Theses rescommendations are purely based on image similarity. This kind of recommendations have high potentials in fashion-based ecommerce industry.

Example Results Example Results

deeplearning_image_similarity's People

Contributors

vinayakarannil avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar

deeplearning_image_similarity's Issues

unable to handle multiple request at same time

Hi Vinay,

can you suggest how to handle multiple request same time.
If more than one request we send only getting result for one request.

Error details:
FileExistsError: [WinError 183] Cannot create a file when that file already exist

Please suggest.

path error

gettting image path error while runing rest-server.py

File "C:\Users\Muhammad Khalid\Desktop\Image Similarity\lib\search.py", line 103, in
image_data = gfile.GFile(image_path, 'rb').read()
NameError: name 'image_path' is not defined

Rest-server file name 'allowed_file' is not defined

2021-05-20 13:50:13.429732: W tensorflow/stream_executor/platform/default/dso_loader.cc:60] Could not load dynamic library 'cudart64_110.dll'; dlerror: cudart64_110.dll not found
2021-05-20 13:50:13.429868: I tensorflow/stream_executor/cuda/cudart_stub.cc:29] Ignore above cudart dlerror if you do not have a GPU set up on your machine.
loaded extracted_features

  • Debugger is active!
  • Debugger PIN: 813-924-762
  • Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
    127.0.0.1 - - [20/May/2021 13:50:38] "←[37mGET / HTTP/1.1←[0m" 200 -
    127.0.0.1 - - [20/May/2021 13:50:38] "←[33mGET /images/logo.svg HTTP/1.1←[0m" 404 -
    image upload
    POST
    RLaver_shoe.jpg
    127.0.0.1 - - [20/May/2021 13:50:43] "←[35m←[1mPOST /imgUpload HTTP/1.1←[0m" 500 -
    Traceback (most recent call last):
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2464, in call
    return self.wsgi_app(environ, start_response)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2450, in wsgi_app
    response = self.handle_exception(e)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1867, in handle_exception
    reraise(exc_type, exc_value, tb)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask_compat.py", line 39, in reraise
    raise value
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2447, in wsgi_app
    response = self.full_dispatch_request()
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1952, in full_dispatch_request
    rv = self.handle_user_exception(e)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1821, in handle_user_exception
    reraise(exc_type, exc_value, tb)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask_compat.py", line 39, in reraise
    raise value
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1950, in full_dispatch_request
    rv = self.dispatch_request()
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1936, in dispatch_request
    return self.view_functionsrule.endpoint
    File "E:\Vatsal\Personal\Machine Learning\Cilans VN\DL\Deeplearning_Image_Similarity-master\server\rest-server.py", line 72, in upload_img
    if file(file.filename):
    TypeError: 'FileStorage' object is not callable
  • Detected change in 'E:\Vatsal\Personal\Machine Learning\Cilans VN\DL\Deeplearning_Image_Similarity-master\server\rest-server.py', reloading
  • Restarting with stat
    2021-05-20 13:55:37.185053: W tensorflow/stream_executor/platform/default/dso_loader.cc:60] Could not load dynamic library 'cudart64_110.dll'; dlerror: cudart64_110.dll not found
    2021-05-20 13:55:37.185222: I tensorflow/stream_executor/cuda/cudart_stub.cc:29] Ignore above cudart dlerror if you do not have a GPU set up on your machine.
    loaded extracted_features
  • Debugger is active!
  • Debugger PIN: 813-924-762
  • Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
    127.0.0.1 - - [20/May/2021 13:56:01] "←[37mGET / HTTP/1.1←[0m" 200 -
    127.0.0.1 - - [20/May/2021 13:56:01] "←[33mGET /images/logo.svg HTTP/1.1←[0m" 404 -
    image upload
    POST
    RLaver_shoe.jpg
    127.0.0.1 - - [20/May/2021 13:56:05] "←[35m←[1mPOST /imgUpload HTTP/1.1←[0m" 500 -
    Traceback (most recent call last):
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2464, in call
    return self.wsgi_app(environ, start_response)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2450, in wsgi_app
    response = self.handle_exception(e)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1867, in handle_exception
    reraise(exc_type, exc_value, tb)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask_compat.py", line 39, in reraise
    raise value
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 2447, in wsgi_app
    response = self.full_dispatch_request()
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1952, in full_dispatch_request
    rv = self.handle_user_exception(e)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1821, in handle_user_exception
    reraise(exc_type, exc_value, tb)
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask_compat.py", line 39, in reraise
    raise value
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1950, in full_dispatch_request
    rv = self.dispatch_request()
    File "E:\Vatsal\Personal\Anaconda3\envs\myenv\lib\site-packages\flask\app.py", line 1936, in dispatch_request
    return self.view_functionsrule.endpoint
    File "E:\Vatsal\Personal\Machine Learning\Cilans VN\DL\Deeplearning_Image_Similarity-master\server\rest-server.py", line 72, in upload_img
    if file and allowed_file(file.filename):
    NameError: name 'allowed_file' is not defined
    Capture

while running image_vectorizer.py getting some errors

################################################################################################################################

This file is used to extract features from dataset and save it on disc

inputs:

outputs:

################################################################################################################################

import os
import random

import numpy as np
import tensorflow as tf

Just disables the warning, doesn't enable AVX/FMA

os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
import pickle

os._warn_preinit_stderr = 0

BOTTLENECK_TENSOR_NAME = 'pool_3/_reshape:0'
BOTTLENECK_TENSOR_SIZE = 2048
MODEL_INPUT_WIDTH = 299
MODEL_INPUT_HEIGHT = 299
MODEL_INPUT_DEPTH = 3
JPEG_DATA_TENSOR_NAME = 'DecodeJpeg/contents:0'
RESIZED_INPUT_TENSOR_NAME = 'ResizeBilinear:0'
MAX_NUM_IMAGES_PER_CLASS = 2 ** 27 - 1 # ~134M

def create_inception_graph():
""""Creates a graph from saved GraphDef file and returns a Graph object.

Returns:
Graph holding the trained Inception network, and various tensors we'll be
manipulating.
"""
with tf.compat.v1.Session() as sess:
model_filename = os.path.join(
'imagenet', 'classify_image_graph_def.pb')
with tf.gfile.FastGFile("imagenet/classify_image_graph_def.pb", 'rb') as f:
graph_def = tf.compat.v1.GraphDef()
graph_def.ParseFromString(f.read())
bottleneck_tensor, jpeg_data_tensor, resized_input_tensor = (
tf.import_graph_def(graph_def, name='', return_elements=[
BOTTLENECK_TENSOR_NAME, JPEG_DATA_TENSOR_NAME,
RESIZED_INPUT_TENSOR_NAME]))
return sess.graph, bottleneck_tensor, jpeg_data_tensor, resized_input_tensor

def run_bottleneck_on_image(sess, image_data, image_data_tensor,
bottleneck_tensor):
bottleneck_values = sess.run(
bottleneck_tensor,
{image_data_tensor: image_data})
bottleneck_values = np.squeeze(bottleneck_values)
return bottleneck_values

Get outputs from second-to-last layer in pre-built model

boots_files = [
'uploads/dogs_and_cats/Boots/' + f
for
f
in
os.listdir('uploads/dogs_and_cats/Boots')
]
sandals_files = [
'uploads/dogs_and_cats/Sandals/' + f
for
f
in
os.listdir('uploads/dogs_and_cats/Sandals')
]
shoes_files = [
'uploads/dogs_and_cats/Shoes/' + f
for
f
in
os.listdir('uploads/dogs_and_cats/Shoes')
]
slippers_files = [
'uploads/dogs_and_cats/Slippers/' + f
for
f
in
os.listdir('uploads/dogs_and_cats/Slippers')
]
apparel_files = [
'uploads/dogs_and_cats/apparel/' + f
for
f
in
os.listdir('uploads/dogs_and_cats/apparel')
]

all_files = boots_files + shoes_files + slippers_files + sandals_files + apparel_files

random.shuffle(all_files)

num_images = 10000
neighbor_list = all_files[:num_images]
with open('neighbor_list_recom.pickle', 'wb') as f:
pickle.dump(neighbor_list, f)
print("saved neighbour list")

extracted_features = np.ndarray((num_images, 2048))
sess = tf.compat.v1.Session()
graph, bottleneck_tensor, jpeg_data_tensor, resized_image_tensor = (create_inception_graph())

for i, filename in enumerate(neighbor_list):

image_data = tf.io.gfile.GFile(filename, 'rb').read()
features = run_bottleneck_on_image(sess, image_data, jpeg_data_tensor, bottleneck_tensor)

extracted_features[i:i + 1] = features

if i % 250 == 0:
    print(i)

np.savetxt("saved_features_recom.txt", extracted_features)
print("saved exttracted features")

==========
Output Error

"C:\Users\Muhammad Khalid\Anaconda3\python.exe" "C:/Users/Muhammad Khalid/Desktop/Recommendation systems using image similarity powered by deep learning/Deeplearning_Image_Similarity-master/server/image_vectorizer.py"

WARNING: Logging before flag parsing goes to stderr.
W0823 21:18:45.101209 20020 init.py:308] Limited tf.compat.v2.summary API due to missing TensorBoard installation.
saved neighbour list

W0823 21:18:45.223723 20020 deprecation.py:323] From C:/Users/Muhammad Khalid/Desktop/Recommendation systems using image similarity powered by deep learning/Deeplearning_Image_Similarity-master/server/image_vectorizer.py:39: FastGFile.init (from tensorflow.python.platform.gfile) is deprecated and will be removed in a future version.
Instructions for updating:
Use tf.gfile.GFile.

Traceback (most recent call last):
File "C:/Users/Muhammad Khalid/Desktop/Recommendation systems using image similarity powered by deep learning/Deeplearning_Image_Similarity-master/server/image_vectorizer.py", line 113, in
image_data = tf.io.gfile.GFile(filename, 'rb').read()

File "C:\Users\Muhammad Khalid\Anaconda3\lib\site-packages\tensorflow\python\lib\io\file_io.py", line 122, in read
self._preread_check()

File "C:\Users\Muhammad Khalid\Anaconda3\lib\site-packages\tensorflow\python\lib\io\file_io.py", line 84, in _preread_check
compat.as_bytes(self.__name), 1024 * 512)

tensorflow.python.framework.errors_impl.UnknownError: NewRandomAccessFile failed to Create/Open: uploads/dogs_and_cats/Sandals/Athletic : Access is denied.
; Input/output error

Process finished with exit code 1

Access is denied

WARNING:tensorflow:From C:\Users\prasad\Downloads\root\server\image_vectorizer.py:36: FastGFile.init (from tensorflow.python.platform.gfile) is deprecated and will be removed in a future version.
Instructions for updating:
Use tf.gfile.GFile.
Traceback (most recent call last):
File "C:\Users\prasad\Downloads\root\server\image_vectorizer.py", line 110, in
image_data = gfile.FastGFile(filename, 'rb').read()
File "C:\python36\lib\site-packages\tensorflow\python\lib\io\file_io.py", line 125, in read
self._preread_check()
File "C:\python36\lib\site-packages\tensorflow\python\lib\io\file_io.py", line 85, in _preread_check
compat.as_bytes(self.__name), 1024 * 512, status)
File "C:\python36\lib\site-packages\tensorflow\python\framework\errors_impl.py", line 528, in exit
c_api.TF_GetCode(self.status.status))
tensorflow.python.framework.errors_impl.UnknownError: NewRandomAccessFile failed to Create/Open: uploads/dogs_and_cats/Shoes/Crib Shoes : Access is denied.

; Input/output error

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.