-
Notifications
You must be signed in to change notification settings - Fork 0
/
gen_vid_w_buffer.py
83 lines (59 loc) · 2.32 KB
/
gen_vid_w_buffer.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
import pickle, time
import matplotlib.image as mpimg
import matplotlib.pyplot as plt
import numpy as np
from scipy.ndimage.measurements import label
from moviepy.editor import VideoFileClip
from IPython.display import HTML
from collections import deque
from lesson_lib import *
with open('Models/model_YUV0_hog_hist_spa.pkl', 'rb') as f:
svc, X_scaler, params = pickle.load(f)
orient = params['orient']
pix_per_cell = params['pix_per_cell']
cell_per_block = params['cell_per_block']
hog_depth = params['hog_depth']
useColor = params['useColor']
useSpatial = params['useSpatial']
colorSpace = 'YUV'#params['colorSpace']
spatial_size = params['spatial_size']
hist_bins = params['hist_bins']
# Get all the windows to be searched
all_search_windows = generate_search_windows(mpimg.imread('test_image.jpg'))
thresh = 12
frame_buffer = 3
history = deque()
def process_image(image):
draw_image = np.copy(image)
image = image.astype(np.float32) / 255.0
hot_windows = search_windows(image, all_search_windows, svc, X_scaler, color_space=colorSpace,
spatial_size=spatial_size, hist_bins=hist_bins,
orient=orient, pix_per_cell=pix_per_cell,
cell_per_block=cell_per_block,
hog_channel=hog_depth, spatial_feat=useSpatial,
hist_feat=useColor, hog_feat=True)
global history
if(len(history) > frame_buffer):
history.popleft()
history.append(hot_windows)
else:
history.append(hot_windows)
box_list = list(history)[0]
for boxes in list(history)[1:]:
box_list += boxes
heat = np.zeros_like(image[:,:,0]).astype(np.float)
# Add heat to each box in box list
heat = add_heat(heat,box_list)
# Apply threshold to help remove false positives
heat = apply_threshold(heat, thresh)
# Visualize the heatmap when displaying
heatmap = np.clip(heat, 0, 255)
# Find final boxes from heatmap using label function
labels = label(heatmap)
draw_img = draw_labeled_bboxes(draw_image, labels)
return draw_image
output_vid = 'output_video/' + str(time.time()) + '.mp4'
clip = VideoFileClip("project_video.mp4").subclip(0, 15)
clip = clip.fl_image(process_image)
clip.write_videofile(output_vid, audio=False)
print('VIDEO SAVED')