forked from bpahuja/Violence-Detection-1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDeploy.py
121 lines (95 loc) · 3.54 KB
/
Deploy.py
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/python3
import os
import sys
import cv2
import numpy as np
import time
from src.ViolenceDetector import *
import settings.DeploySettings as deploySettings
import settings.DataSettings as dataSettings
import src.data.ImageUtils as ImageUtils
def PrintHelp():
print("Usage:")
print("\t $(ThisScript) $(PATH_FILE_NAME_OF_SOURCE_VIDEO)")
print()
print("or, specified $(PATH_FILE_NAME_TO_SAVE_RESULT) to save detection result:")
print("\t $(ThisScript) $(PATH_FILE_NAME_OF_SOURCE_VIDEO) $(PATH_FILE_NAME_TO_SAVE_RESULT)")
print()
class VideoSavor:
def AppendFrame(self, image_):
self.outputStream.write(image_)
def __init__(self, targetFileName, videoCapture):
width = int( deploySettings.DISPLAY_IMAGE_SIZE )
height = int( deploySettings.DISPLAY_IMAGE_SIZE )
frameRate = int( videoCapture.get(cv2.CAP_PROP_FPS) )
codec = cv2.VideoWriter_fourcc(*'XVID')
self.outputStream = cv2.VideoWriter(targetFileName + ".avi", codec, frameRate, (width, height) )
def PrintUnsmoothedResults(unsmoothedResults_):
print("Unsmoothed results:")
print("\t [ ")
print("\t ", end='')
for i, eachResult in enumerate(unsmoothedResults_):
if i % 10 == 9:
print( str(eachResult)+", " )
print("\t ", end='')
else:
print( str(eachResult)+", ", end='')
print("\n\t ]")
def DetectViolence(PATH_FILE_NAME_OF_SOURCE_VIDEO, PATH_FILE_NAME_TO_SAVE_RESULT):
violenceDetector = ViolenceDetector()
videoReader = cv2.VideoCapture(PATH_FILE_NAME_OF_SOURCE_VIDEO)
shouldSaveResult = (PATH_FILE_NAME_TO_SAVE_RESULT != None)
if shouldSaveResult:
videoSavor = VideoSavor(PATH_FILE_NAME_TO_SAVE_RESULT + "_Result", videoReader)
listOfForwardTime = []
isCurrentFrameValid, currentImage = videoReader.read()
while isCurrentFrameValid:
netInput = ImageUtils.ConvertImageFrom_CV_to_NetInput(currentImage)
startDetectTime = time.time()
isFighting = violenceDetector.Detect(netInput)
endDetectTime = time.time()
listOfForwardTime.append(endDetectTime - startDetectTime)
targetSize = deploySettings.DISPLAY_IMAGE_SIZE - 2*deploySettings.BORDER_SIZE
currentImage = cv2.resize(currentImage, (targetSize, targetSize))
if isFighting:
resultImage = cv2.copyMakeBorder(currentImage,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
cv2.BORDER_CONSTANT,
value=deploySettings.FIGHT_BORDER_COLOR)
else:
resultImage = cv2.copyMakeBorder(currentImage,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
deploySettings.BORDER_SIZE,
cv2.BORDER_CONSTANT,
value=deploySettings.NO_FIGHT_BORDER_COLOR)
cv2.imshow("Violence Detection", resultImage)
if shouldSaveResult:
videoSavor.AppendFrame(resultImage)
userResponse = cv2.waitKey(1)
if userResponse == ord('q'):
videoReader.release()
cv2.destroyAllWindows()
break
else:
isCurrentFrameValid, currentImage = videoReader.read()
PrintUnsmoothedResults(violenceDetector.unsmoothedResults)
averagedForwardTime = np.mean(listOfForwardTime)
print("Averaged Forward Time: ", averagedForwardTime)
if __name__ == '__main__':
if len(sys.argv) >= 2:
PATH_FILE_NAME_OF_SOURCE_VIDEO = sys.argv[1]
try:
PATH_FILE_NAME_TO_SAVE_RESULT = sys.argv[2]
except:
PATH_FILE_NAME_TO_SAVE_RESULT = None
if os.path.isfile(PATH_FILE_NAME_OF_SOURCE_VIDEO):
DetectViolence(PATH_FILE_NAME_OF_SOURCE_VIDEO, PATH_FILE_NAME_TO_SAVE_RESULT)
else:
raise ValueError("Not such file: " + videoPathName)
else:
PrintHelp()