-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy patharg_extractor.py
More file actions
66 lines (59 loc) · 4.54 KB
/
arg_extractor.py
File metadata and controls
66 lines (59 loc) · 4.54 KB
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
import argparse
available_models = ['TestModel', 'UNet']
def str2bool(v):
if v.lower() in ('yes', 'true', 't', 'y', '1'):
return True
elif v.lower() in ('no', 'false', 'f', 'n', '0'):
return False
else:
raise argparse.ArgumentTypeError('Boolean value expected.')
def get_args():
"""
Returns a namedtuple with arguments extracted from the command line.
:return: A namedtuple with arguments
"""
parser = argparse.ArgumentParser(
description='Welcome to the MLP course\'s Pytorch training and inference helper script')
parser.add_argument('--batch_size', nargs="?", type=int, default=100, help='Batch_size for experiment')
parser.add_argument('--continue_from_epoch', nargs="?", type=int, default=-1, help='Epoch you want to continue training from while restarting an experiment (from scrach (-1))')
parser.add_argument('--seed', nargs="?", type=int, default=81820,
help='Seed to use for random number generator for experiment')
parser.add_argument('--image_num_channels', nargs="?", type=int, default=3,
help='The channel dimensionality of our image-data')
parser.add_argument('--image_height', nargs="?", type=int, default=32, help='Height of image data')
parser.add_argument('--image_width', nargs="?", type=int, default=32, help='Width of image data')
parser.add_argument('--num_stages', nargs="?", type=int, default=3,
help='Number of convolutional stages in the network. A stage is considered a sequence of '
'convolutional layers where the input volume remains the same in the spacial dimension and'
' is always terminated by a dimensionality reduction stage')
parser.add_argument('--num_blocks_per_stage', nargs="?", type=int, default=5,
help='Number of convolutional blocks in each stage, not including the reduction stage.'
' A convolutional block is made up of two convolutional layers activated using the '
' leaky-relu non-linearity')
parser.add_argument('--num_filters', nargs="?", type=int, default=16,
help='Number of convolutional filters per convolutional layer in the network (excluding '
'dimensionality reduction layers)')
parser.add_argument('--num_epochs', nargs="?", type=int, default=100, help='Total number of epochs for model training')
parser.add_argument('--num_classes', nargs="?", type=int, default=100, help='Number of classes in the dataset')
parser.add_argument('--experiment_name', nargs="?", type=str, default="exp_1",
help='Experiment name - to be used for building the experiment folder')
parser.add_argument('--use_gpu', nargs="?", type=str2bool, default=True,
help='A flag indicating whether we will use GPU acceleration or not')
parser.add_argument('--weight_decay_coefficient', nargs="?", type=float, default=0,
help='Weight decay to use for Adam')
parser.add_argument('--block_type', type=str, default='conv_block',
help='Type of convolutional blocks to use in our network '
'(This argument will be useful in running experiments to debug your network)')
parser.add_argument('--lr', nargs="?", type=float, default=1e-3, help='Learning rate for optimizer')
parser.add_argument('--num_workers', nargs="?", type=int, default=0,
help='Number of workers to use for data loading')
parser.add_argument('--model_name', type=str, default='TestModel',
help=f'Name of the model to use for training. This should be one of {available_models}')
args = parser.parse_args()
print(args)
return args
# COMMANDS TO RUN
# TestModel (BASE)
# python train_evaluate_image_classification_system.py --model_name TestModel --experiment_name simple_experiment --num_epochs 5 --num_workers 0 --batch_size 4 --num_filters 16 --num_classes 4 --use_gpu False --continue_from_epoch -1
# python train_evaluate_image_classification_system.py --model_name UNet --experiment_name simple_experiment --num_epochs 5 --num_workers 0 --batch_size 4 --num_filters 16 --num_classes 4 --use_gpu False --continue_from_epoch -1
# python train_evaluate_image_classification_system.py --model_name UNet --experiment_name simple_experiment_nf64 --num_epochs 20 --num_workers 0 --batch_size 4 --num_filters 64 --num_classes 4 --use_gpu False --continue_from_epoch -1