-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathvideo-test.py
executable file
·92 lines (76 loc) · 3.34 KB
/
video-test.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
#!/bin/ipython
# ---LICENSE-BEGIN - DO NOT CHANGE OR MOVE THIS HEADER
# This file is part of the Neurorobotics Platform software
# Copyright (C) 2014,2015,2016,2017 Human Brain Project
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
# ---LICENSE-END
import numpy as np
import cv2
import pyNN.nest as sim
import pathlib as plb
import time
import common as cm
import network as nw
import visualization as vis
args = cm.parse_args()
# Train weights
weights_dict, feature_imgs_dict = nw.train_weights(args.feature_dir)
# Open the video capture and writer objects
cap = cv2.VideoCapture(args.target_name)
cap_width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
cap_height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
writer = cv2.VideoWriter('video_S1_reconstructions/{}.avi'.format(\
plb.Path(args.target_name).stem),
int(cap.get(cv2.CAP_PROP_FOURCC)),
cap.get(cv2.CAP_PROP_FPS), (cap_width, cap_height),
isColor=False)
sim.setup(threads=4, spike_precision='on_grid')
# Set up the network
layer_collection = {} # layer name -> dict of S1 layers of type
# 'scale -> layer list'
layer_collection['input'] = nw.create_input_layers_for_scales(\
np.zeros((cap_height, cap_width)), args.scales)
layer_collection['S1'] = nw.create_S1_layers(layer_collection['input'],
weights_dict, args)
nw.create_cross_layer_inhibition(layer_collection['S1'])
# We build only the S1 layer for the moment, to speed up the simulation time
for layers in layer_collection['S1'].values():
for layer in layers:
layer.population.record('spikes')
# The actual frame-by-frame simulation and input neuron updating
t1 = time.clock()
#for i in range(int(cap.get(cv2.CAP_PROP_FRAME_COUNT))):
for i in range(args.frames):
t2 = time.clock()
img = cap.read()[1]
img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# It's assumed that the image is already filtered, so no filtering is
# required
nw.change_rates_for_scales(layer_collection['input'], img)
sim.run(50)
# Refresh the current spike counts
for layers in layer_collection['S1'].values():
for layer in layers:
layer.update_spike_counts()
reconstructed_img = vis.create_S1_feature_image(img, layer_collection,
feature_imgs_dict, args)[1]
reconstructed_img = cv2.convertScaleAbs(reconstructed_img)
writer.write(reconstructed_img)
print('Frame', i, 'took', time.clock() - t2, 's to finish')
print('Processing', args.frames, 'frames took', time.clock() - t1, 's')
cap.release()
writer.release()
sim.end()