-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathLRS2_gen.py
54 lines (47 loc) · 2.61 KB
/
LRS2_gen.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
from Visual_perturb import *
import random
import numpy as np
import os
import argparse
def video_gen(args):
with open(args.split_file, 'r') as f:
lines = f.readlines()
test_list = []
for l in lines:
test_list.append(l.strip().split()[0])
for mode in ['occlusion_and_noise', 'occlusion', 'noise']:
random.seed(10)
np.random.seed(10)
save_dir = f'{args.LRS2_save_loc}_{mode}'
for kk, test_file in enumerate(test_list):
f_name = os.path.join(args.LRS2_main_dir, test_file + '.mp4')
l_name = os.path.join(args.LRS2_landmark_dir, test_file + '.pkl')
sequence, landmarks = load_video(f_name, l_name)
if mode != 'noise':
freq = random.choice([1, 2, 3])
bgr = True if mode == 'occlusion' else False
sequence, _ = occlude_sequence(args.occlusion, args.occlusion_mask, sequence, landmarks, freq=freq, bgr=bgr, data='LRS2')
if mode != 'occlusion':
freq = random.choice([1, 2, 3])
sequence = occlude_sequence_noise(sequence, freq=freq)
if not os.path.exists(os.path.join(save_dir, test_file.split('/')[0])):
os.makedirs(os.path.join(save_dir, test_file.split('/')[0]))
write_video(sequence, os.path.join(save_dir, test_file + '.mp4'))
print(f'{mode}:{kk}/{len(test_list)}', end='\r')
print('')
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('-s', '--split_file', type=str, default='./datasets/LRS2-BBC/test.txt',
help='directory of test split file')
parser.add_argument('-m', '--LRS2_main_dir', type=str, default='./datasets/LRS2-BBC/main',
required=False, help='directory of the original lrs2 audio dataset')
parser.add_argument('-l', '--LRS2_landmark_dir', type=str, default='./datasets/LRS2_landmarks/main',
required=False, help='directory of the original lrs2 audio dataset')
parser.add_argument('-o', '--LRS2_save_loc', type=str, default='./datasets/LRS2-BBC/main3',
help='directory to save audio corruption files')
parser.add_argument('--occlusion', action='store_true', default='./occlusion_patch/object_image_sr',
help='location of occlusion patch')
parser.add_argument('--occlusion_mask', action='store_true', default='./occlusion_patch/object_mask_x4',
help='location of occlusion patch mask')
args = parser.parse_args()
video_gen(args)