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
|
from typing import TypedDict, Optional, Union, Tuple, Dict
from utils.dataset import ClipClasses, ClipConditions, ClipViews
class SystemConfiguration(TypedDict):
disable_acc: bool
CUDA_VISIBLE_DEVICES: str
save_dir: str
class DatasetConfiguration(TypedDict):
name: str
root_dir: str
train_size: int
num_sampled_frames: int
discard_threshold: int
selector: Optional[Dict[str, Union[ClipClasses, ClipConditions, ClipViews]]]
num_input_channels: int
frame_size: Tuple[int, int]
cache_on: bool
class DataloaderConfiguration(TypedDict):
batch_size: Tuple[int, int]
num_workers: int
pin_memory: bool
class ModelHPConfiguration(TypedDict):
ae_feature_channels: int
f_a_c_p_dims: Tuple[int, int, int]
hpm_scales: Tuple[int, ...]
hpm_use_avg_pool: bool
hpm_use_max_pool: bool
fpfe_feature_channels: int
fpfe_kernel_sizes: Tuple[Tuple, ...]
fpfe_paddings: Tuple[Tuple, ...]
fpfe_halving: Tuple[int, ...]
tfa_squeeze_ratio: int
tfa_num_parts: int
embedding_dims: int
triplet_margin: float
class OptimizerHPConfiguration(TypedDict):
lr: int
betas: Tuple[float, float]
weight_decay: float
class SchedulerHPConfiguration(TypedDict):
step_size: int
gamma: float
class HyperparameterConfiguration(TypedDict):
model: ModelHPConfiguration
optimizer: OptimizerHPConfiguration
scheduler: SchedulerHPConfiguration
class ModelConfiguration(TypedDict):
name: str
restore_iter: int
total_iter: int
class Configuration(TypedDict):
system: SystemConfiguration
dataset: DatasetConfiguration
dataloader: DataloaderConfiguration
hyperparameter: HyperparameterConfiguration
model: ModelConfiguration
|