forked from tanghaoyu258/ACRM-for-moment-retrieval
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
58 lines (48 loc) · 1.83 KB
/
main.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
import os
import cv2
import time
import torch
import logging
import datetime
import argparse
import numpy as np
from config import cfg
from utils.miscellaneous import mkdir
from utils.logger import setup_logger
from engine import trainer, tester
def main():
os.environ["CUDA_VISIBLE_DEVICES"] = "0"
parser = argparse.ArgumentParser(description="PyTorch Query Localization in Videos Training")
parser.add_argument(
"--config-file",
default="experiments/charades_sta_train.yaml",
# default="experiments/anet_cap_train.yaml",
# default="experiments/tacos_train.yaml",
metavar="FILE",
help="path to config file",
type=str,)
args = parser.parse_args()
experiment_name = args.config_file.split("/")[-1]
log_directory = args.config_file.replace(experiment_name,"logs/")
vis_directory = args.config_file.replace(experiment_name,"visualization/")
experiment_name = experiment_name.replace(".yaml","")
cfg.merge_from_list(['EXPERIMENT_NAME', experiment_name, 'LOG_DIRECTORY', log_directory, "VISUALIZATION_DIRECTORY", vis_directory])
cfg.merge_from_file(args.config_file)
output_dir = "./{}".format(cfg.LOG_DIRECTORY)
if output_dir:
mkdir(output_dir)
mkdir("./checkpoints/{}".format(cfg.EXPERIMENT_NAME))
logger = setup_logger("mlnlp", output_dir, cfg.EXPERIMENT_NAME + ".txt", 0)
logger.info("Starting moment localization with dynamic filters")
logger.info(cfg.EXPERIMENT_NAME)
torch.backends.cudnn.deterministic = True
torch.backends.cudnn.benchmark = False
# torch.backends.cudnn.enabled = False
if cfg.ENGINE_STAGE == "TRAINER":
print('#######')
print(cfg.DYNAMIC_FILTER.LSTM_VIDEO.DROPOUT)
trainer(cfg)
elif cfg.ENGINE_STAGE == "TESTER":
tester(cfg)
if __name__ == "__main__":
main()