-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplay_video.py
204 lines (182 loc) · 8.83 KB
/
play_video.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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
import os
import re
import logging
from backend.server import Server
from frontend.client import Client
from dds_utils import (ServerConfig, read_results_dict,
evaluate, write_stats)
import sys
from munch import *
import yaml
from pathlib import Path
def main(args):
logging.basicConfig(
format="%(name)s -- %(levelname)s -- %(lineno)s -- %(message)s",
level=args.verbosity.upper())
logger = logging.getLogger("dds")
logger.addHandler(logging.NullHandler())
# Make simulation objects
logger.info(f"Starting server with high threshold of "
f"{args.high_threshold} low threshold of "
f"{args.low_threshold} tracker length of "
f"{args.tracker_length}")
config = args
# config = ServerConfig(
# args.resolutions[0], args.resolutions[1], args.qp[0], args.qp[1],
# args.batch_size, args.high_threshold, args.low_threshold,
# args.max_object_size, args.min_object_size, args.tracker_length,
# args.boundary, args.intersection_threshold, args.tracking_threshold,
# args.suppression_threshold, args.simulate, args.rpn_enlarge_ratio,
# args.prune_score, args.objfilter_iou, args.size_obj)
server = None
mode = None
results, bw = None, None
if args.simulate:
raise NotImplementedError("We do not support simulation anymore")
elif not args.simulate and not args.hname and args.high_resolution != -1:
mode = "emulation"
logger.warning(f"Running DDS in EMULATION mode on {args.video_name}")
server = Server(config)
logger.info("Starting client")
client = Client(args.hname, config, server)
# Run emulation
results, bw = client.analyze_video_emulate(
args.video_name, args.high_images_path,
args.enforce_iframes, args.low_results_path, args.debug_mode)
"""
single_instance['video_name'] = f'results/{result_file_name}'
single_instance['high_images_path'] = f'{original_images_dir}' ../dataset/my/src
single_instance['outfile'] = 'stats'
single_instance['ground_truth'] = f'results/{video_name}_gt'
single_instance['low_results_path'] = f'results/{video_name}_mpeg_{low_res}_{low_qp}'
"""
elif not args.simulate and not args.hname:
mode = "mpeg"
logger.warning(f"Running in MPEG mode with resolution "
f"{args.low_resolution} on {args.video_name}")
server = Server(config)
logger.info("Starting client")
client = Client(args.hname, config, server)
results, bw = client.analyze_video_mpeg(
args.video_name, args.high_images_path, args.enforce_iframes)
elif not args.simulate and args.hname:
mode = "implementation"
logger.warning(
f"Running DDS using a server client implementation with "
f"server running on {args.hname} using video {args.hname}")
logger.info("Starting client")
client = Client(args.hname, config, server)
results,lowbw =client.analyze_video(
args.video_name, args.high_images_path, config,
args.enforce_iframes)
# SR result evaluate =======================================================================注意缩进
f1 = 0
stats = (0, 0, 0)
number_of_frames = len(
[x for x in os.listdir(args.high_images_path) if "png" in x])
# print("x for x in os.listdir(args.high_images_path) if png in x:",number_of_frames)
gtfile=Path(args.ground_truth)
if gtfile.exists():
ground_truth_dict = read_results_dict(args.ground_truth)
# single_instance['ground_truth'] = f'results/{video_name}_gt'
print("args.ground_truth", args.ground_truth)
logger.info("Reading ground truth results complete")
tp, fp, fn, _, _, _, f1 = evaluate(
number_of_frames - 1, results.regions_dict, ground_truth_dict,
args.low_threshold, 0.5, 0.4, 0.4)
stats = (tp, fp, fn)
logger.info(f"Got an f1 score of {f1} "
f"for this experiment {mode} with "
f"tp {stats[0]} fp {stats[1]} fn {stats[2]} "
)
else:
logger.info("No groundtruth given skipping evalution")
# Write evaluation results to file
write_stats(args.outfile, f"{args.video_name}", config, f1,
stats, (lowbw,-1), number_of_frames, mode) # bw设置为
# SR result evaluate =======================================================================
# results, low_phase_results,bw = client.analyze_video(
# args.video_name, args.high_images_path, config,
# args.enforce_iframes)
"""
# reference
single_instance['video_name'] = f'results/{result_file_name}'
single_instance['high_images_path'] = f'{original_images_dir}' ../dataset/my/src
single_instance['outfile'] = 'stats'
single_instance['ground_truth'] = f'results/{video_name}_gt'
single_instance['low_results_path'] = f'results/{video_name}_mpeg_{low_res}_{low_qp}'
"""
"""
# if evaluation,remove zhushi below
# Evaluation and writing results
# Read Groundtruth results
low, high = bw
f1 = 0
stats = (0, 0, 0)
number_of_frames = len(
[x for x in os.listdir(args.high_images_path) if "png" in x])
# print("x for x in os.listdir(args.high_images_path) if png in x:",number_of_frames)
if args.ground_truth:
ground_truth_dict = read_results_dict(args.ground_truth)
# single_instance['ground_truth'] = f'results/{video_name}_gt'
print("args.ground_truth",args.ground_truth)
logger.info("Reading ground truth results complete")
# if picture not include objects below evaluate bao cuo
tp, fp, fn, _, _, _, f1 = evaluate(
number_of_frames - 1, results.regions_dict, ground_truth_dict,
args.low_threshold, 0.5, 0.4, 0.4)
stats = (tp, fp, fn)
logger.info(f"Got an f1 score of {f1} "
f"for this experiment {mode} with "
f"tp {stats[0]} fp {stats[1]} fn {stats[2]} "
f"with total bandwidth {sum(bw)}")
# tpl, fpl, fnl, _, _, _, f1l = evaluate(
# number_of_frames - 1, low_phase_results.regions_dict, ground_truth_dict,
# args.low_threshold, 0.5, 0.4, 0.4)
# logger.info(f"=======low_phase_results got an f1 score of {f1l} "
# f"for this experiment {mode} with "
# f"tp {tpl} fp {fpl} fn {fnl} "
# f"with total bandwidth {sum(bw)}")
else:
logger.info("No groundtruth given skipping evalution")
# Write evaluation results to file
write_stats(args.outfile, f"{args.video_name}", config, f1,
stats, bw, number_of_frames, mode)
"""
if __name__ == "__main__":
# load configuration dictonary from command line
# use munch to provide class-like accessment to python dictionary
args = munchify(yaml.load(sys.argv[1], Loader=yaml.SafeLoader))
if not args.simulate and not args.hname and args.high_resolution != -1:
if not args.high_images_path:
print("Running DDS in emulation mode requires raw/high "
"resolution images")
exit()
if not re.match("DEBUG|INFO|WARNING|CRITICAL", args.verbosity.upper()):
print("Incorrect argument for verbosity."
"Verbosity can only be one of the following:\n"
"\tdebug\n\tinfo\n\twarning\n\terror")
exit()
if args.estimate_banwidth and not args.high_images_path:
print("DDS needs location of high resolution images to "
"calculate true bandwidth estimate")
exit()
if not args.simulate and args.high_resolution != -1:
if args.low_images_path:
print("Discarding low images path")
args.low_images_path = None
args.intersection_threshold = 1.0
if args.method != "dds":
assert args.high_resolution == -1, "Only dds support two quality levels"
if args.high_resolution == -1:
print("Only one resolution given, running MPEG emulation")
assert args.high_qp == -1, "MPEG emulation only support one QP"
else:
assert args.low_resolution <= args.high_resolution, \
f"The resolution of low quality({args.low_resolution})"\
f"can't be larger than high quality({args.high_resolution})"
assert not(args.low_resolution == args.high_resolution and
args.low_qp < args.high_qp),\
f"Under the same resolution, the QP of low quality({args.low_qp})"\
f"can't be higher than the QP of high quality({args.high_qp})"
main(args)