-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSS_main.py
40 lines (38 loc) · 1.47 KB
/
SS_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
import numpy as np
import os
from prototypes.reinforcement_based_mcmc import RL_MCMC
import sys
if __name__=='__main__':
home = os.path.expanduser('~')
dataset = sys.argv[1]
place = sys.argv[2] # Documents/research for beeblebrox; barn for CCNI
data_home = home + '/' + place + '/EP_project/data/'
results_home = home + '/' + place + '/stochastic_search/results/'
num_iters = 51
cutoff_time = 36000
start = int(sys.argv[3])
end = int(sys.argv[4])
# Empty features directory
import glob
files = glob.glob(data_home + 'features/RL1/*.npz')
for f in files:
if os.path.exists(f):
os.remove(f)
pipeline = {}
pipeline['feature_extraction'] = ["VGG", "haralick", "inception"]
pipeline['dimensionality_reduction'] = ["PCA", "ISOMAP"]
pipeline['learning_algorithm'] = ["SVM", "RF"]
pipeline['haralick_distance'] = range(1, 4)
pipeline['pca_whiten'] = [True, False]
pipeline['n_neighbors'] = range(3, 8)
pipeline['n_components'] = range(2, 5)
pipeline['n_estimators'] = np.round(np.linspace(8, 300, 10)).tolist()
pipeline['max_features'] = np.arange(0.3, 0.8, 0.1).tolist()
pipeline['svm_gamma'] = np.linspace(0.01, 8, 10).tolist()
pipeline['svm_C'] = np.linspace(0.1, 100, 10).tolist()
# CONTROL
type1 = 'RL_MCMC'
for i in range(start, end):
rm = RL_MCMC(data_name=dataset, data_loc=data_home, cutoff_time=cutoff_time, results_loc=results_home, run=i+1, type1=type1, pipeline=pipeline, path_resources=12, hyper_resources=1, iters=num_iters)
rm.populate_paths()
rm.rlMcmc()