forked from matsui528/sis
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.py
More file actions
58 lines (46 loc) · 1.8 KB
/
server.py
File metadata and controls
58 lines (46 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import os
import numpy as np
from PIL import Image
from feature_extractor import FeatureExtractor
import glob
import pickle
from datetime import datetime
from flask import Flask, request, render_template
import time
import multiprocessing
from functools import partial
app = Flask(__name__)
# Read image features
fe = FeatureExtractor()
features = []
img_paths = []
for feature_path in glob.glob("static/feature/*"):
features.append(pickle.load(open(feature_path, 'rb')))
img_paths.append('static/img/' + os.path.splitext(os.path.basename(feature_path))[0] + '.jpg')
def CalNorm(query, feature):
return np.linalg.norm(feature - query)
cores = multiprocessing.cpu_count()
# cores = cores * 2
pool = multiprocessing.Pool(processes=cores)
@app.route('/', methods=['GET', 'POST'])
def index():
if request.method == 'POST':
file = request.files['query_img']
img = Image.open(file.stream) # PIL image
uploaded_img_path = "static/uploaded/" + datetime.now().strftime("%Y%m%d-%H%M%S-%f") + "_" + file.filename
img.save(uploaded_img_path)
query = fe.extract(img)
startTime = time.time()
dists = pool.map(partial(CalNorm, query), features)
# dists = np.linalg.norm(features - query, axis=1) # Do search
ids = np.argsort(dists)[:48] # Top 48 results
scores = [(dists[id], img_paths[id]) for id in ids]
endTime = time.time()
app.logger.warning('Cost: %f', endTime - startTime)
return render_template('index.html',
query_path=uploaded_img_path,
scores=scores, total=len(scores), f_total=len(features), cost=endTime - startTime)
else:
return render_template('index.html')
if __name__=="__main__":
app.run(host="0.0.0.0", port=8000, debug=True)