-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathrun_bbh_cifar_resnet_exp.py
98 lines (90 loc) · 4.11 KB
/
run_bbh_cifar_resnet_exp.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
import experiments_cifar as experiments
import networks
if __name__ == '__main__':
import argparse
parser = argparse.ArgumentParser(
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('--logdir', '-p', help='tb directory',
default='/vol/biomedic2/np716/bbh_nips/cifar_resnet'
'/bbh')
parser.add_argument('--experiment', '-x', help='tb directory',
default='test')
parser.add_argument('--seed', '-s', help='seed',
default=42, type=int)
parser.add_argument('--epochs', '-e', help='tb directory',
default=5, type=int)
parser.add_argument('--output_mc', '-m', help='', default=False,
action='store_true')
parser.add_argument('--annealing', '-a', help='', default=False,
action='store_true')
parser.add_argument('--random_weights', '-r', help='', default=0, type=int)
parser.add_argument('--lr', '-d', help='', default=0.0001, type=float)
parser.add_argument('--prior_scale', help='', default=1.,
type=float)
parser.add_argument('--noise_shape', help='', default=1,
type=int)
parser.add_argument('--layer_wise_gen', help='', default=False,
action='store_true')
parser.add_argument('--slice_last_dim', help='', default=False,
action='store_true')
parser.add_argument('--force_zero_mean', help='', default=False,
action='store_true')
parser.add_argument('--kl_method', '-k', help='', default='approx',
choices=['approx', 'disc'])
parser.add_argument('--no_kl', help='', default=False,
action='store_true')
parser.add_argument('--independent_noise', help='', default=False,
action='store_true')
parser.add_argument('--full_kernel', help='', default=False,
action='store_true')
parser.add_argument('--cuda', '-c', default='0')
args = parser.parse_args()
import os
import tensorflow as tf
os.environ['CUDA_VISIBLE_DEVICES'] = args.cuda
config = {}
config['logdir'] = os.path.join(args.logdir, args.experiment)
config['seed'] = args.seed
config['random_weights'] = args.random_weights
config['num_samples'] = 5
config['annealing'] = args.annealing
config['learning_rate'] = args.lr
if args.no_kl:
config['annealing_epoch_start'] = args.epochs
else:
config['annealing_epoch_start'] = 20
config['annealing_epoch_length'] = 15
config['disc_units'] = [64, 64, 64]
config['h_units'] = [64, 256, 512]
config['disc_pretrain'] = 100
config['disc_train'] = 1
config['epochs'] = args.epochs
config['prior_scale'] = args.prior_scale
config['full_kernel'] = args.full_kernel
config['args'] = str(args)
print(args)
print('##########################')
if args.kl_method == 'approx':
tf.reset_default_graph()
config['experiment'] = 'bbh_klapprox'
ops = networks.get_bbh_cifar_resnet(
{}, num_samples=5, sample_output=args.output_mc,
noise_shape=args.noise_shape, layer_wise=args.layer_wise_gen,
slice_last_dim=args.slice_last_dim, num_slices=1,
force_zero_mean=args.force_zero_mean,
aligned_noise=not args.independent_noise,
h_units=config['h_units'])
experiments.run_klapprox_experiment(ops, config)
elif args.kl_method == 'disc':
tf.reset_default_graph()
config['experiment'] = 'bbh_disc'
ops = networks.get_bbh_cifar_resnet(
{}, num_samples=5, sample_output=args.output_mc,
noise_shape=args.noise_shape, layer_wise=args.layer_wise_gen,
slice_last_dim=args.slice_last_dim, num_slices=1,
force_zero_mean=args.force_zero_mean,
aligned_noise=not args.independent_noise,
h_units=config['h_units'])
experiments.run_disc_experiment(ops, config)
else:
print('didnt know what to do')