forked from ArnaudFickinger/DeepSequence-PyTorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoptions.py
106 lines (84 loc) · 5.65 KB
/
options.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
99
100
101
102
103
104
105
106
###
'''
April 2019
Code by: Arnaud Fickinger
'''
###
import argparse
import os
class Options():
def __init__(self):
self.parser = argparse.ArgumentParser()
self.initialized = False
def initialize(self):
#Main parameter
self.parser.add_argument('--custom_dataset', dest='custom_dataset', action='store_true', default=True)
self.parser.add_argument('--dataset_path', type=str, default="BLAT_ECOLX_hmmerbit_plmc_n5_m30_f50_t0.2_r24-286_id100_b105.a2m")
self.parser.add_argument('--dataset_id', type=str, default="BLAT_ECOLX")
self.parser.add_argument('--phenotype_name', type=str, default="2500")
self.parser.add_argument('--mutation_path', type=str, default="./mutations/BLAT_ECOLX_Ranganathan2015.csv")
self.parser.add_argument('--theta', type=float, default=0.2)
self.parser.add_argument('--epochs', type=int, default=2)
self.parser.add_argument('--mutation_iterations', type=int, default=3)
self.parser.add_argument('--plot_spearman', dest='plot_spearman', action='store_true', default=True)
self.parser.add_argument('--spearman_every', type=int, default=10)
self.parser.add_argument('--saving_path', type=str, default="./checkpoint/")
self.parser.add_argument('--plots_path', type=str, default="./plots/")
#Training parameter
self.parser.add_argument('--is_train', dest='is_train', action='store_true', default=True)
self.parser.add_argument('--test_algo', dest='test_algo', action='store_true', default=True)
#Importance Weighted Sampler
self.parser.add_argument('--k_IWS', type=int, default=50)
self.parser.add_argument('--IWS', dest='IWS', action='store_true', default=False)
self.parser.add_argument('--IWS_debug', dest='IWS_debug', action='store_true', default=False)
#Pruning
self.parser.add_argument('--prune', dest='prune', action='store_true', default=False)
self.parser.add_argument('--prune_encoder', dest='prune_encoder', action='store_true', default=True)
self.parser.add_argument('--prune_decoder', dest='prune_decoder', action='store_true', default=False)
self.parser.add_argument('--show_mask', dest='show_mask', action='store_true', default=True)
self.parser.add_argument('--save_every_rates', dest='save_every_rates', action='store_true', default=False)
#Stochastic vs Detemrministic Weight
self.parser.add_argument('--stoch_det', dest='stoch_det', action='store_true', default=True)
#Pytorch parameters
self.parser.add_argument('--random_seed', type=int, default=42)
self.parser.add_argument('--warm_up', type=int, default=0)
self.parser.add_argument('--saving_path', type=str, default="./checkpoint/")
self.parser.add_argument('--plots_path', type=str, default="./plots/")
self.parser.add_argument('--arrays_path', type=str, default="./arrays/")
self.parser.add_argument('--save_model_every', type=int, default=30000)
self.parser.add_argument('--save_plot_every', type=int, default=30000)
self.parser.add_argument('--save_spearman_every', type=int, default=30000)
self.parser.add_argument('--continue_training', type=int, default=0)
self.parser.add_argument('--batch_size', type=int, default=100)
self.parser.add_argument('--lr', type=float, default=1e-3)
self.parser.add_argument('--neff', type=float, default = 0)#535.5874
self.parser.add_argument('--theano_test', dest='theano_test', action='store_true', default=False)
self.parser.add_argument('--dropout', type=float, default=0)
#Parameters of the data
# self.parser.add_argument('--dataset', type=str, default="DLG4_RAT")#'BLAT_ECOLX'
# self.parser.add_argument('--theta', type=float, default=0.2)
self.parser.add_argument('--alphabet_size', type=int, default=20, help='size of the alphabet')
self.parser.add_argument('--sequence_length', type=int, default=84, help='length of the sequence') #253
#Parameters of the VAE
self.parser.add_argument('--latent_dim', type=int, default=30, help='dimension of the latent space')
self.parser.add_argument('--is_sparse', action='store_true', default=True)
self.parser.add_argument('--has_temperature', action='store_true', default=True)
self.parser.add_argument('--has_dictionary', action='store_true', default=True)
self.parser.add_argument('--is_semi_supervised', action='store_true', default=False)
#Parameters of the encoder
self.parser.add_argument('--enc_h1_dim', type=int, default=1500, help='dimension of the first hl of the enc')
self.parser.add_argument('--enc_h2_dim', type=int, default=1500, help='dimension of the second hl of the enc')
#Parameters of the decoder
self.parser.add_argument('--dec_h1_dim', type=int, default=100, help='dimension of the first hl of the dec')
self.parser.add_argument('--dec_h2_dim', type=int, default=2000, help='dimension of the second hl of the dec')
self.parser.add_argument('--cw_inner_dimension', type=int, default=40, help='inner dimension of the product CW')
#Sparsity parameters
self.parser.add_argument('--nb_patterns', type=int, default=4, help='nb of times S is repeated')
self.parser.add_argument('--mu_sparse', type=float, default=-12.36, help='sparse prior mean')
self.parser.add_argument('--logsigma_sparse', type=float, default=0.602, help='sparse prior sigma')
self.initialized = True
def parse(self):
if not self.initialized:
self.initialize()
self.opt = self.parser.parse_args()
return self.opt