Mercurial > repos > bgruening > sklearn_model_fit
annotate stacking_ensembles.py @ 0:734c66aa945a draft
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
| author | bgruening | 
|---|---|
| date | Fri, 01 Nov 2019 17:18:28 -0400 | 
| parents | |
| children | 26decbf4bdb8 | 
| rev | line source | 
|---|---|
| 
0
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
1 import argparse | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
2 import ast | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
3 import json | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
4 import mlxtend.regressor | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
5 import mlxtend.classifier | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
6 import pandas as pd | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
7 import pickle | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
8 import sklearn | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
9 import sys | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
10 import warnings | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
11 from sklearn import ensemble | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
12 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
13 from galaxy_ml.utils import (load_model, get_cv, get_estimator, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
14 get_search_params) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
15 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
16 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
17 warnings.filterwarnings('ignore') | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
18 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
19 N_JOBS = int(__import__('os').environ.get('GALAXY_SLOTS', 1)) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
20 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
21 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
22 def main(inputs_path, output_obj, base_paths=None, meta_path=None, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
23 outfile_params=None): | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
24 """ | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
25 Parameter | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
26 --------- | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
27 inputs_path : str | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
28 File path for Galaxy parameters | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
29 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
30 output_obj : str | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
31 File path for ensemble estimator ouput | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
32 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
33 base_paths : str | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
34 File path or paths concatenated by comma. | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
35 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
36 meta_path : str | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
37 File path | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
38 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
39 outfile_params : str | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
40 File path for params output | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
41 """ | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
42 with open(inputs_path, 'r') as param_handler: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
43 params = json.load(param_handler) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
44 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
45 estimator_type = params['algo_selection']['estimator_type'] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
46 # get base estimators | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
47 base_estimators = [] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
48 for idx, base_file in enumerate(base_paths.split(',')): | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
49 if base_file and base_file != 'None': | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
50 with open(base_file, 'rb') as handler: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
51 model = load_model(handler) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
52 else: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
53 estimator_json = (params['base_est_builder'][idx] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
54 ['estimator_selector']) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
55 model = get_estimator(estimator_json) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
56 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
57 if estimator_type.startswith('sklearn'): | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
58 named = model.__class__.__name__.lower() | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
59 named = 'base_%d_%s' % (idx, named) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
60 base_estimators.append((named, model)) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
61 else: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
62 base_estimators.append(model) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
63 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
64 # get meta estimator, if applicable | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
65 if estimator_type.startswith('mlxtend'): | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
66 if meta_path: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
67 with open(meta_path, 'rb') as f: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
68 meta_estimator = load_model(f) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
69 else: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
70 estimator_json = (params['algo_selection'] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
71 ['meta_estimator']['estimator_selector']) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
72 meta_estimator = get_estimator(estimator_json) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
73 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
74 options = params['algo_selection']['options'] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
75 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
76 cv_selector = options.pop('cv_selector', None) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
77 if cv_selector: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
78 splitter, groups = get_cv(cv_selector) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
79 options['cv'] = splitter | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
80 # set n_jobs | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
81 options['n_jobs'] = N_JOBS | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
82 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
83 weights = options.pop('weights', None) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
84 if weights: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
85 weights = ast.literal_eval(weights) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
86 if weights: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
87 options['weights'] = weights | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
88 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
89 mod_and_name = estimator_type.split('_') | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
90 mod = sys.modules[mod_and_name[0]] | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
91 klass = getattr(mod, mod_and_name[1]) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
92 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
93 if estimator_type.startswith('sklearn'): | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
94 options['n_jobs'] = N_JOBS | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
95 ensemble_estimator = klass(base_estimators, **options) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
96 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
97 elif mod == mlxtend.classifier: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
98 ensemble_estimator = klass( | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
99 classifiers=base_estimators, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
100 meta_classifier=meta_estimator, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
101 **options) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
102 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
103 else: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
104 ensemble_estimator = klass( | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
105 regressors=base_estimators, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
106 meta_regressor=meta_estimator, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
107 **options) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
108 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
109 print(ensemble_estimator) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
110 for base_est in base_estimators: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
111 print(base_est) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
112 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
113 with open(output_obj, 'wb') as out_handler: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
114 pickle.dump(ensemble_estimator, out_handler, pickle.HIGHEST_PROTOCOL) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
115 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
116 if params['get_params'] and outfile_params: | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
117 results = get_search_params(ensemble_estimator) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
118 df = pd.DataFrame(results, columns=['', 'Parameter', 'Value']) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
119 df.to_csv(outfile_params, sep='\t', index=False) | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
120 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
121 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
122 if __name__ == '__main__': | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
123 aparser = argparse.ArgumentParser() | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
124 aparser.add_argument("-b", "--bases", dest="bases") | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
125 aparser.add_argument("-m", "--meta", dest="meta") | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
126 aparser.add_argument("-i", "--inputs", dest="inputs") | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
127 aparser.add_argument("-o", "--outfile", dest="outfile") | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
128 aparser.add_argument("-p", "--outfile_params", dest="outfile_params") | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
129 args = aparser.parse_args() | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
130 | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
131 main(args.inputs, args.outfile, base_paths=args.bases, | 
| 
 
734c66aa945a
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit eb703290e2589561ea215c84aa9f71bcfe1712c6"
 
bgruening 
parents:  
diff
changeset
 | 
132 meta_path=args.meta, outfile_params=args.outfile_params) | 
