You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

158 lines
5.0 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. from flask import Flask, request
  2. from flask_restful import Resource, Api, abort
  3. import json
  4. import io
  5. import base64
  6. from PIL import Image
  7. import sys
  8. import datetime
  9. import cv2
  10. if sys.platform == "win32":
  11. import tensorflow as tf
  12. import numpy as np
  13. import pickle
  14. sys.path.insert(0, r'C:\Users\Tednokent01\Downloads\MyCity\traffic_analyzer')
  15. from utils import label_map_util
  16. from utils import visualization_utils as vis_util
  17. app = Flask(__name__)
  18. api = Api(app)
  19. score_dict = {
  20. 1: 1,
  21. 2: 1,
  22. 3: 1,
  23. 4: 1,
  24. 5: 1,
  25. 6: 1,
  26. 7: 1,
  27. 8: 1
  28. }
  29. with open("modules/databases/complaints.json","r") as f:
  30. complaints = json.load(f)
  31. if sys.platform == "win32":
  32. # Path to frozen detection graph. This is the actual model that is used for the object detection.
  33. PATH_TO_CKPT = 'modules/trainedModels/ssd_mobilenet_RoadDamageDetector.pb'
  34. # List of the strings that is used to add correct label for each box.
  35. PATH_TO_LABELS = 'modules/trainedModels/crack_label_map.pbtxt'
  36. NUM_CLASSES = 8
  37. detection_graph = tf.Graph()
  38. with detection_graph.as_default():
  39. od_graph_def = tf.GraphDef()
  40. with tf.gfile.GFile(PATH_TO_CKPT, 'rb') as fid:
  41. serialized_graph = fid.read()
  42. od_graph_def.ParseFromString(serialized_graph)
  43. tf.import_graph_def(od_graph_def, name='')
  44. label_map = label_map_util.load_labelmap(PATH_TO_LABELS)
  45. categories = label_map_util.convert_label_map_to_categories(label_map, max_num_classes=NUM_CLASSES, use_display_name=True)
  46. category_index = label_map_util.create_category_index(categories)
  47. def load_image_into_numpy_array(image):
  48. (im_width, im_height) = image.size
  49. return np.array(image.getdata()).reshape(
  50. (im_height, im_width, 3)).astype(np.uint8)
  51. def process_img(img_base64):
  52. if sys.platform == "win32":
  53. img = Image.open(io.BytesIO(base64.b64decode(img_base64)))
  54. with detection_graph.as_default():
  55. with tf.Session(graph=detection_graph) as sess:
  56. # Definite input and output Tensors for detection_graph
  57. image_tensor = detection_graph.get_tensor_by_name('image_tensor:0')
  58. # Each box represents a part of the image where a particular object was detected.
  59. detection_boxes = detection_graph.get_tensor_by_name('detection_boxes:0')
  60. # Each score represent how level of confidence for each of the objects.
  61. # Score is shown on the result image, together with the class label.
  62. detection_scores = detection_graph.get_tensor_by_name('detection_scores:0')
  63. detection_classes = detection_graph.get_tensor_by_name('detection_classes:0')
  64. num_detections = detection_graph.get_tensor_by_name('num_detections:0')
  65. # the array based representation of the image will be used later in order to prepare the
  66. # result image with boxes and labels on it.
  67. image_np = load_image_into_numpy_array(img)
  68. # Expand dimensions since the model expects images to have shape: [1, None, None, 3]
  69. image_np_expanded = np.expand_dims(image_np, axis=0)
  70. # Actual detection.
  71. (boxes, scores, classes, num) = sess.run(
  72. [detection_boxes, detection_scores, detection_classes, num_detections],
  73. feed_dict={image_tensor: image_np_expanded})
  74. # Visualization of the results of a detection.
  75. vis_util.visualize_boxes_and_labels_on_image_array(
  76. image_np,
  77. np.squeeze(boxes),
  78. np.squeeze(classes).astype(np.int32),
  79. np.squeeze(scores),
  80. category_index,
  81. min_score_thresh=0.3,
  82. use_normalized_coordinates=True,
  83. line_thickness=8)
  84. output_dict = {'detection_classes': np.squeeze(classes).astype(np.int32), 'detection_scores': np.squeeze(scores)}
  85. defects = []
  86. for index, i in enumerate(output_dict['detection_classes']):
  87. score = output_dict['detection_scores'][index]
  88. if score > 0.3:
  89. defects.append(i)
  90. priority = 0
  91. for i in defects:
  92. priority += score_dict[i]
  93. if priority > 10:
  94. priority = 10
  95. _, buffer = cv2.imencode('.jpg', image_np)
  96. return base64.b64encode(buffer).decode('ascii'),priority,defects
  97. return img_base64, 7,["unprocessed"]
  98. class Complaint(Resource):
  99. def post(self):
  100. args = request.form.to_dict()
  101. complaint = args
  102. complaint["response"] = {"status":False}
  103. img_process,priority,tags = process_img(complaint["img"])
  104. complaint["img"] = img_process
  105. complaint["response"]["priority"] = str(priority)
  106. complaint["tags"] = list(map(str, tags))
  107. complaint["datetime"] = datetime.datetime.now().strftime('%b-%d-%I:%M %p-%G')
  108. try:
  109. complaints[complaint["id"]].append(complaint)
  110. except KeyError:
  111. complaints[complaint["id"]] = [complaint]
  112. del complaints[complaint["id"]][-1]["id"]
  113. with open('modules/databases/complaints.json', 'w') as complaints_file:
  114. json.dump(complaints, complaints_file, indent=4)
  115. class Complaints(Resource):
  116. def post(self):
  117. id = request.form["id"]
  118. return complaints[id]
  119. class ComplaintsUpdate(Resource):
  120. def get(self):
  121. args = request.args
  122. complaints[args.get("id")][int(args.get("index"))]["response"]["message"] = args.get("message")
  123. complaints[args["id"]][int(args["index"])]["response"]["status"] = True
  124. with open('modules/databases/complaints.json', 'w') as complaints_file:
  125. json.dump(complaints, complaints_file, indent=4)
  126. return