Mercurial > repos > bgruening > sklearn_to_categorical
annotate search_model_validation.py @ 4:14180f9c831e draft
planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit f031d8ddfb73cec24572648666ac44ee47f08aad
| author | bgruening | 
|---|---|
| date | Thu, 11 Aug 2022 09:45:22 +0000 | 
| parents | f93f0cdbaf18 | 
| children | b650955a20cc | 
| rev | line source | 
|---|---|
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 1 import argparse | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 2 import collections | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 3 import json | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 4 import os | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 5 import pickle | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 6 import sys | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 7 import warnings | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 8 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 9 import imblearn | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 10 import joblib | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 11 import numpy as np | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 12 import pandas as pd | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 13 import skrebate | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 14 from galaxy_ml.utils import (clean_params, get_cv, | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 15 get_main_estimator, get_module, get_scoring, | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 16 load_model, read_columns, SafeEval, try_get_attr) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 17 from scipy.io import mmread | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 18 from sklearn import (cluster, decomposition, feature_selection, | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 19 kernel_approximation, model_selection, preprocessing) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 20 from sklearn.exceptions import FitFailedWarning | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 21 from sklearn.model_selection import _search, _validation | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 22 from sklearn.model_selection._validation import _score, cross_validate | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 23 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 24 _fit_and_score = try_get_attr("galaxy_ml.model_validations", "_fit_and_score") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 25 setattr(_search, "_fit_and_score", _fit_and_score) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 26 setattr(_validation, "_fit_and_score", _fit_and_score) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 27 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 28 N_JOBS = int(os.environ.get("GALAXY_SLOTS", 1)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 29 # handle disk cache | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 30 CACHE_DIR = os.path.join(os.getcwd(), "cached") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 31 del os | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 32 NON_SEARCHABLE = ("n_jobs", "pre_dispatch", "memory", "_path", "nthread", "callbacks") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 33 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 34 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 35 def _eval_search_params(params_builder): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 36 search_params = {} | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 37 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 38 for p in params_builder["param_set"]: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 39 search_list = p["sp_list"].strip() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 40 if search_list == "": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 41 continue | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 42 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 43 param_name = p["sp_name"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 44 if param_name.lower().endswith(NON_SEARCHABLE): | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 45 print( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 46 "Warning: `%s` is not eligible for search and was " | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 47 "omitted!" % param_name | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 48 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 49 continue | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 50 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 51 if not search_list.startswith(":"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 52 safe_eval = SafeEval(load_scipy=True, load_numpy=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 53 ev = safe_eval(search_list) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 54 search_params[param_name] = ev | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 55 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 56 # Have `:` before search list, asks for estimator evaluatio | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 57 safe_eval_es = SafeEval(load_estimators=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 58 search_list = search_list[1:].strip() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 59 # TODO maybe add regular express check | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 60 ev = safe_eval_es(search_list) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 61 preprocessings = ( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 62 preprocessing.StandardScaler(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 63 preprocessing.Binarizer(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 64 preprocessing.MaxAbsScaler(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 65 preprocessing.Normalizer(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 66 preprocessing.MinMaxScaler(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 67 preprocessing.PolynomialFeatures(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 68 preprocessing.RobustScaler(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 69 feature_selection.SelectKBest(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 70 feature_selection.GenericUnivariateSelect(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 71 feature_selection.SelectPercentile(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 72 feature_selection.SelectFpr(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 73 feature_selection.SelectFdr(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 74 feature_selection.SelectFwe(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 75 feature_selection.VarianceThreshold(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 76 decomposition.FactorAnalysis(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 77 decomposition.FastICA(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 78 decomposition.IncrementalPCA(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 79 decomposition.KernelPCA(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 80 decomposition.LatentDirichletAllocation(random_state=0, n_jobs=N_JOBS), | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 81 decomposition.MiniBatchDictionaryLearning( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 82 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 83 ), | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 84 decomposition.MiniBatchSparsePCA(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 85 decomposition.NMF(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 86 decomposition.PCA(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 87 decomposition.SparsePCA(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 88 decomposition.TruncatedSVD(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 89 kernel_approximation.Nystroem(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 90 kernel_approximation.RBFSampler(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 91 kernel_approximation.AdditiveChi2Sampler(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 92 kernel_approximation.SkewedChi2Sampler(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 93 cluster.FeatureAgglomeration(), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 94 skrebate.ReliefF(n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 95 skrebate.SURF(n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 96 skrebate.SURFstar(n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 97 skrebate.MultiSURF(n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 98 skrebate.MultiSURFstar(n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 99 imblearn.under_sampling.ClusterCentroids(random_state=0, n_jobs=N_JOBS), | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 100 imblearn.under_sampling.CondensedNearestNeighbour( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 101 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 102 ), | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 103 imblearn.under_sampling.EditedNearestNeighbours( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 104 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 105 ), | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 106 imblearn.under_sampling.RepeatedEditedNearestNeighbours( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 107 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 108 ), | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 109 imblearn.under_sampling.AllKNN(random_state=0, n_jobs=N_JOBS), | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 110 imblearn.under_sampling.InstanceHardnessThreshold( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 111 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 112 ), | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 113 imblearn.under_sampling.NearMiss(random_state=0, n_jobs=N_JOBS), | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 114 imblearn.under_sampling.NeighbourhoodCleaningRule( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 115 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 116 ), | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 117 imblearn.under_sampling.OneSidedSelection( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 118 random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 119 ), | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 120 imblearn.under_sampling.RandomUnderSampler(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 121 imblearn.under_sampling.TomekLinks(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 122 imblearn.over_sampling.ADASYN(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 123 imblearn.over_sampling.RandomOverSampler(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 124 imblearn.over_sampling.SMOTE(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 125 imblearn.over_sampling.SVMSMOTE(random_state=0, n_jobs=N_JOBS), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 126 imblearn.over_sampling.BorderlineSMOTE(random_state=0, n_jobs=N_JOBS), | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 127 imblearn.over_sampling.SMOTENC( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 128 categorical_features=[], random_state=0, n_jobs=N_JOBS | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 129 ), | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 130 imblearn.combine.SMOTEENN(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 131 imblearn.combine.SMOTETomek(random_state=0), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 132 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 133 newlist = [] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 134 for obj in ev: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 135 if obj is None: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 136 newlist.append(None) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 137 elif obj == "all_0": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 138 newlist.extend(preprocessings[0:35]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 139 elif obj == "sk_prep_all": # no KernalCenter() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 140 newlist.extend(preprocessings[0:7]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 141 elif obj == "fs_all": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 142 newlist.extend(preprocessings[7:14]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 143 elif obj == "decomp_all": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 144 newlist.extend(preprocessings[14:25]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 145 elif obj == "k_appr_all": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 146 newlist.extend(preprocessings[25:29]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 147 elif obj == "reb_all": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 148 newlist.extend(preprocessings[30:35]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 149 elif obj == "imb_all": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 150 newlist.extend(preprocessings[35:54]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 151 elif type(obj) is int and -1 < obj < len(preprocessings): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 152 newlist.append(preprocessings[obj]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 153 elif hasattr(obj, "get_params"): # user uploaded object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 154 if "n_jobs" in obj.get_params(): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 155 newlist.append(obj.set_params(n_jobs=N_JOBS)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 156 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 157 newlist.append(obj) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 158 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 159 sys.exit("Unsupported estimator type: %r" % (obj)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 160 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 161 search_params[param_name] = newlist | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 162 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 163 return search_params | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 164 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 165 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 166 def _handle_X_y( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 167 estimator, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 168 params, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 169 infile1, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 170 infile2, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 171 loaded_df={}, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 172 ref_seq=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 173 intervals=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 174 targets=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 175 fasta_path=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 176 ): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 177 """read inputs | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 178 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 179 Params | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 180 ------- | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 181 estimator : estimator object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 182 params : dict | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 183 Galaxy tool parameter inputs | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 184 infile1 : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 185 File path to dataset containing features | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 186 infile2 : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 187 File path to dataset containing target values | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 188 loaded_df : dict | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 189 Contains loaded DataFrame objects with file path as keys | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 190 ref_seq : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 191 File path to dataset containing genome sequence file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 192 interval : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 193 File path to dataset containing interval file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 194 targets : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 195 File path to dataset compressed target bed file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 196 fasta_path : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 197 File path to dataset containing fasta file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 198 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 199 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 200 Returns | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 201 ------- | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 202 estimator : estimator object after setting new attributes | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 203 X : numpy array | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 204 y : numpy array | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 205 """ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 206 estimator_params = estimator.get_params() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 207 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 208 input_type = params["input_options"]["selected_input"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 209 # tabular input | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 210 if input_type == "tabular": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 211 header = "infer" if params["input_options"]["header1"] else None | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 212 column_option = params["input_options"]["column_selector_options_1"][ | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 213 "selected_column_selector_option" | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 214 ] | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 215 if column_option in [ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 216 "by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 217 "all_but_by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 218 "by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 219 "all_but_by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 220 ]: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 221 c = params["input_options"]["column_selector_options_1"]["col1"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 222 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 223 c = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 224 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 225 df_key = infile1 + repr(header) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 226 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 227 if df_key in loaded_df: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 228 infile1 = loaded_df[df_key] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 229 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 230 df = pd.read_csv(infile1, sep="\t", header=header, parse_dates=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 231 loaded_df[df_key] = df | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 232 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 233 X = read_columns(df, c=c, c_option=column_option).astype(float) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 234 # sparse input | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 235 elif input_type == "sparse": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 236 X = mmread(open(infile1, "r")) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 237 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 238 # fasta_file input | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 239 elif input_type == "seq_fasta": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 240 pyfaidx = get_module("pyfaidx") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 241 sequences = pyfaidx.Fasta(fasta_path) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 242 n_seqs = len(sequences.keys()) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 243 X = np.arange(n_seqs)[:, np.newaxis] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 244 for param in estimator_params.keys(): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 245 if param.endswith("fasta_path"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 246 estimator.set_params(**{param: fasta_path}) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 247 break | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 248 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 249 raise ValueError( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 250 "The selected estimator doesn't support " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 251 "fasta file input! Please consider using " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 252 "KerasGBatchClassifier with " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 253 "FastaDNABatchGenerator/FastaProteinBatchGenerator " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 254 "or having GenomeOneHotEncoder/ProteinOneHotEncoder " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 255 "in pipeline!" | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 256 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 257 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 258 elif input_type == "refseq_and_interval": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 259 path_params = { | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 260 "data_batch_generator__ref_genome_path": ref_seq, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 261 "data_batch_generator__intervals_path": intervals, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 262 "data_batch_generator__target_path": targets, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 263 } | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 264 estimator.set_params(**path_params) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 265 n_intervals = sum(1 for line in open(intervals)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 266 X = np.arange(n_intervals)[:, np.newaxis] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 267 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 268 # Get target y | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 269 header = "infer" if params["input_options"]["header2"] else None | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 270 column_option = params["input_options"]["column_selector_options_2"][ | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 271 "selected_column_selector_option2" | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 272 ] | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 273 if column_option in [ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 274 "by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 275 "all_but_by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 276 "by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 277 "all_but_by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 278 ]: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 279 c = params["input_options"]["column_selector_options_2"]["col2"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 280 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 281 c = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 282 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 283 df_key = infile2 + repr(header) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 284 if df_key in loaded_df: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 285 infile2 = loaded_df[df_key] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 286 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 287 infile2 = pd.read_csv(infile2, sep="\t", header=header, parse_dates=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 288 loaded_df[df_key] = infile2 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 289 | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 290 y = read_columns( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 291 infile2, c=c, c_option=column_option, sep="\t", header=header, parse_dates=True | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 292 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 293 if len(y.shape) == 2 and y.shape[1] == 1: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 294 y = y.ravel() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 295 if input_type == "refseq_and_interval": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 296 estimator.set_params(data_batch_generator__features=y.ravel().tolist()) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 297 y = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 298 # end y | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 299 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 300 return estimator, X, y | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 301 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 302 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 303 def _do_outer_cv(searcher, X, y, outer_cv, scoring, error_score="raise", outfile=None): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 304 """Do outer cross-validation for nested CV | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 305 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 306 Parameters | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 307 ---------- | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 308 searcher : object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 309 SearchCV object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 310 X : numpy array | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 311 Containing features | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 312 y : numpy array | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 313 Target values or labels | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 314 outer_cv : int or CV splitter | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 315 Control the cv splitting | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 316 scoring : object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 317 Scorer | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 318 error_score: str, float or numpy float | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 319 Whether to raise fit error or return an value | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 320 outfile : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 321 File path to store the restuls | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 322 """ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 323 if error_score == "raise": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 324 rval = cross_validate( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 325 searcher, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 326 X, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 327 y, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 328 scoring=scoring, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 329 cv=outer_cv, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 330 n_jobs=N_JOBS, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 331 verbose=0, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 332 error_score=error_score, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 333 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 334 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 335 warnings.simplefilter("always", FitFailedWarning) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 336 with warnings.catch_warnings(record=True) as w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 337 try: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 338 rval = cross_validate( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 339 searcher, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 340 X, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 341 y, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 342 scoring=scoring, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 343 cv=outer_cv, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 344 n_jobs=N_JOBS, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 345 verbose=0, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 346 error_score=error_score, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 347 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 348 except ValueError: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 349 pass | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 350 for warning in w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 351 print(repr(warning.message)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 352 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 353 keys = list(rval.keys()) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 354 for k in keys: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 355 if k.startswith("test"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 356 rval["mean_" + k] = np.mean(rval[k]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 357 rval["std_" + k] = np.std(rval[k]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 358 if k.endswith("time"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 359 rval.pop(k) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 360 rval = pd.DataFrame(rval) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 361 rval = rval[sorted(rval.columns)] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 362 rval.to_csv(path_or_buf=outfile, sep="\t", header=True, index=False) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 363 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 364 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 365 def _do_train_test_split_val( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 366 searcher, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 367 X, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 368 y, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 369 params, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 370 error_score="raise", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 371 primary_scoring=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 372 groups=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 373 outfile=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 374 ): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 375 """do train test split, searchCV validates on the train and then use | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 376 the best_estimator_ to evaluate on the test | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 377 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 378 Returns | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 379 -------- | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 380 Fitted SearchCV object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 381 """ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 382 train_test_split = try_get_attr("galaxy_ml.model_validations", "train_test_split") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 383 split_options = params["outer_split"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 384 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 385 # splits | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 386 if split_options["shuffle"] == "stratified": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 387 split_options["labels"] = y | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 388 X, X_test, y, y_test = train_test_split(X, y, **split_options) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 389 elif split_options["shuffle"] == "group": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 390 if groups is None: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 391 raise ValueError( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 392 "No group based CV option was choosen for " "group shuffle!" | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 393 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 394 split_options["labels"] = groups | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 395 if y is None: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 396 X, X_test, groups, _ = train_test_split(X, groups, **split_options) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 397 else: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 398 X, X_test, y, y_test, groups, _ = train_test_split( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 399 X, y, groups, **split_options | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 400 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 401 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 402 if split_options["shuffle"] == "None": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 403 split_options["shuffle"] = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 404 X, X_test, y, y_test = train_test_split(X, y, **split_options) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 405 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 406 if error_score == "raise": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 407 searcher.fit(X, y, groups=groups) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 408 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 409 warnings.simplefilter("always", FitFailedWarning) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 410 with warnings.catch_warnings(record=True) as w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 411 try: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 412 searcher.fit(X, y, groups=groups) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 413 except ValueError: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 414 pass | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 415 for warning in w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 416 print(repr(warning.message)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 417 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 418 scorer_ = searcher.scorer_ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 419 if isinstance(scorer_, collections.Mapping): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 420 is_multimetric = True | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 421 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 422 is_multimetric = False | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 423 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 424 best_estimator_ = getattr(searcher, "best_estimator_") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 425 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 426 # TODO Solve deep learning models in pipeline | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 427 if best_estimator_.__class__.__name__ == "KerasGBatchClassifier": | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 428 test_score = best_estimator_.evaluate( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 429 X_test, scorer=scorer_, is_multimetric=is_multimetric | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 430 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 431 else: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 432 test_score = _score( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 433 best_estimator_, X_test, y_test, scorer_, is_multimetric=is_multimetric | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 434 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 435 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 436 if not is_multimetric: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 437 test_score = {primary_scoring: test_score} | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 438 for key, value in test_score.items(): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 439 test_score[key] = [value] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 440 result_df = pd.DataFrame(test_score) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 441 result_df.to_csv(path_or_buf=outfile, sep="\t", header=True, index=False) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 442 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 443 return searcher | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 444 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 445 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 446 def main( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 447 inputs, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 448 infile_estimator, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 449 infile1, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 450 infile2, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 451 outfile_result, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 452 outfile_object=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 453 outfile_weights=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 454 groups=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 455 ref_seq=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 456 intervals=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 457 targets=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 458 fasta_path=None, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 459 ): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 460 """ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 461 Parameter | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 462 --------- | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 463 inputs : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 464 File path to galaxy tool parameter | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 465 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 466 infile_estimator : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 467 File path to estimator | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 468 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 469 infile1 : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 470 File path to dataset containing features | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 471 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 472 infile2 : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 473 File path to dataset containing target values | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 474 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 475 outfile_result : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 476 File path to save the results, either cv_results or test result | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 477 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 478 outfile_object : str, optional | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 479 File path to save searchCV object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 480 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 481 outfile_weights : str, optional | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 482 File path to save model weights | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 483 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 484 groups : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 485 File path to dataset containing groups labels | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 486 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 487 ref_seq : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 488 File path to dataset containing genome sequence file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 489 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 490 intervals : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 491 File path to dataset containing interval file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 492 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 493 targets : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 494 File path to dataset compressed target bed file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 495 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 496 fasta_path : str | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 497 File path to dataset containing fasta file | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 498 """ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 499 warnings.simplefilter("ignore") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 500 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 501 # store read dataframe object | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 502 loaded_df = {} | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 503 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 504 with open(inputs, "r") as param_handler: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 505 params = json.load(param_handler) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 506 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 507 # Override the refit parameter | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 508 params["search_schemes"]["options"]["refit"] = ( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 509 True if params["save"] != "nope" else False | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 510 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 511 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 512 with open(infile_estimator, "rb") as estimator_handler: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 513 estimator = load_model(estimator_handler) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 514 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 515 optimizer = params["search_schemes"]["selected_search_scheme"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 516 optimizer = getattr(model_selection, optimizer) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 517 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 518 # handle gridsearchcv options | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 519 options = params["search_schemes"]["options"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 520 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 521 if groups: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 522 header = ( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 523 "infer" if (options["cv_selector"]["groups_selector"]["header_g"]) else None | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 524 ) | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 525 column_option = options["cv_selector"]["groups_selector"][ | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 526 "column_selector_options_g" | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 527 ]["selected_column_selector_option_g"] | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 528 if column_option in [ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 529 "by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 530 "all_but_by_index_number", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 531 "by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 532 "all_but_by_header_name", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 533 ]: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 534 c = options["cv_selector"]["groups_selector"]["column_selector_options_g"][ | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 535 "col_g" | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 536 ] | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 537 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 538 c = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 539 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 540 df_key = groups + repr(header) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 541 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 542 groups = pd.read_csv(groups, sep="\t", header=header, parse_dates=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 543 loaded_df[df_key] = groups | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 544 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 545 groups = read_columns( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 546 groups, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 547 c=c, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 548 c_option=column_option, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 549 sep="\t", | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 550 header=header, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 551 parse_dates=True, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 552 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 553 groups = groups.ravel() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 554 options["cv_selector"]["groups_selector"] = groups | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 555 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 556 splitter, groups = get_cv(options.pop("cv_selector")) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 557 options["cv"] = splitter | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 558 primary_scoring = options["scoring"]["primary_scoring"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 559 # get_scoring() expects secondary_scoring to be a comma separated string (not a list) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 560 # Check if secondary_scoring is specified | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 561 secondary_scoring = options["scoring"].get("secondary_scoring", None) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 562 if secondary_scoring is not None: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 563 # If secondary_scoring is specified, convert the list into comman separated string | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 564 options["scoring"]["secondary_scoring"] = ",".join( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 565 options["scoring"]["secondary_scoring"] | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 566 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 567 options["scoring"] = get_scoring(options["scoring"]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 568 if options["error_score"]: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 569 options["error_score"] = "raise" | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 570 else: | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 571 options["error_score"] = np.nan | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 572 if options["refit"] and isinstance(options["scoring"], dict): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 573 options["refit"] = primary_scoring | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 574 if "pre_dispatch" in options and options["pre_dispatch"] == "": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 575 options["pre_dispatch"] = None | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 576 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 577 params_builder = params["search_schemes"]["search_params_builder"] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 578 param_grid = _eval_search_params(params_builder) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 579 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 580 estimator = clean_params(estimator) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 581 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 582 # save the SearchCV object without fit | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 583 if params["save"] == "save_no_fit": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 584 searcher = optimizer(estimator, param_grid, **options) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 585 print(searcher) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 586 with open(outfile_object, "wb") as output_handler: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 587 pickle.dump(searcher, output_handler, pickle.HIGHEST_PROTOCOL) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 588 return 0 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 589 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 590 # read inputs and loads new attributes, like paths | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 591 estimator, X, y = _handle_X_y( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 592 estimator, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 593 params, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 594 infile1, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 595 infile2, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 596 loaded_df=loaded_df, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 597 ref_seq=ref_seq, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 598 intervals=intervals, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 599 targets=targets, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 600 fasta_path=fasta_path, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 601 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 602 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 603 # cache iraps_core fits could increase search speed significantly | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 604 memory = joblib.Memory(location=CACHE_DIR, verbose=0) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 605 main_est = get_main_estimator(estimator) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 606 if main_est.__class__.__name__ == "IRAPSClassifier": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 607 main_est.set_params(memory=memory) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 608 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 609 searcher = optimizer(estimator, param_grid, **options) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 610 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 611 split_mode = params["outer_split"].pop("split_mode") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 612 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 613 if split_mode == "nested_cv": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 614 # make sure refit is choosen | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 615 # this could be True for sklearn models, but not the case for | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 616 # deep learning models | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 617 if not options["refit"] and not all( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 618 hasattr(estimator, attr) for attr in ("config", "model_type") | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 619 ): | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 620 warnings.warn("Refit is change to `True` for nested validation!") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 621 setattr(searcher, "refit", True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 622 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 623 outer_cv, _ = get_cv(params["outer_split"]["cv_selector"]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 624 # nested CV, outer cv using cross_validate | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 625 if options["error_score"] == "raise": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 626 rval = cross_validate( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 627 searcher, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 628 X, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 629 y, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 630 scoring=options["scoring"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 631 cv=outer_cv, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 632 n_jobs=N_JOBS, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 633 verbose=options["verbose"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 634 return_estimator=(params["save"] == "save_estimator"), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 635 error_score=options["error_score"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 636 return_train_score=True, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 637 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 638 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 639 warnings.simplefilter("always", FitFailedWarning) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 640 with warnings.catch_warnings(record=True) as w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 641 try: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 642 rval = cross_validate( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 643 searcher, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 644 X, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 645 y, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 646 scoring=options["scoring"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 647 cv=outer_cv, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 648 n_jobs=N_JOBS, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 649 verbose=options["verbose"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 650 return_estimator=(params["save"] == "save_estimator"), | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 651 error_score=options["error_score"], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 652 return_train_score=True, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 653 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 654 except ValueError: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 655 pass | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 656 for warning in w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 657 print(repr(warning.message)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 658 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 659 fitted_searchers = rval.pop("estimator", []) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 660 if fitted_searchers: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 661 import os | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 662 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 663 pwd = os.getcwd() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 664 save_dir = os.path.join(pwd, "cv_results_in_folds") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 665 try: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 666 os.mkdir(save_dir) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 667 for idx, obj in enumerate(fitted_searchers): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 668 target_name = "cv_results_" + "_" + "split%d" % idx | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 669 target_path = os.path.join(pwd, save_dir, target_name) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 670 cv_results_ = getattr(obj, "cv_results_", None) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 671 if not cv_results_: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 672 print("%s is not available" % target_name) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 673 continue | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 674 cv_results_ = pd.DataFrame(cv_results_) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 675 cv_results_ = cv_results_[sorted(cv_results_.columns)] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 676 cv_results_.to_csv(target_path, sep="\t", header=True, index=False) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 677 except Exception as e: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 678 print(e) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 679 finally: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 680 del os | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 681 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 682 keys = list(rval.keys()) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 683 for k in keys: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 684 if k.startswith("test"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 685 rval["mean_" + k] = np.mean(rval[k]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 686 rval["std_" + k] = np.std(rval[k]) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 687 if k.endswith("time"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 688 rval.pop(k) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 689 rval = pd.DataFrame(rval) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 690 rval = rval[sorted(rval.columns)] | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 691 rval.to_csv(path_or_buf=outfile_result, sep="\t", header=True, index=False) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 692 # deprecate train test split mode | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 693 """searcher = _do_train_test_split_val( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 694 searcher, X, y, params, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 695 primary_scoring=primary_scoring, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 696 error_score=options['error_score'], | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 697 groups=groups, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 698 outfile=outfile_result)""" | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 699 return 0 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 700 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 701 # no outer split | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 702 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 703 searcher.set_params(n_jobs=N_JOBS) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 704 if options["error_score"] == "raise": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 705 searcher.fit(X, y, groups=groups) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 706 else: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 707 warnings.simplefilter("always", FitFailedWarning) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 708 with warnings.catch_warnings(record=True) as w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 709 try: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 710 searcher.fit(X, y, groups=groups) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 711 except ValueError: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 712 pass | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 713 for warning in w: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 714 print(repr(warning.message)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 715 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 716 cv_results = pd.DataFrame(searcher.cv_results_) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 717 cv_results = cv_results[sorted(cv_results.columns)] | 
| 1 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 718 cv_results.to_csv( | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 719 path_or_buf=outfile_result, sep="\t", header=True, index=False | 
| 
f93f0cdbaf18
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit ea12f973df4b97a2691d9e4ce6bf6fae59d57717"
 bgruening parents: 
0diff
changeset | 720 ) | 
| 0 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 721 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 722 memory.clear(warn=False) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 723 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 724 # output best estimator, and weights if applicable | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 725 if outfile_object: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 726 best_estimator_ = getattr(searcher, "best_estimator_", None) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 727 if not best_estimator_: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 728 warnings.warn( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 729 "GridSearchCV object has no attribute " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 730 "'best_estimator_', because either it's " | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 731 "nested gridsearch or `refit` is False!" | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 732 ) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 733 return | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 734 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 735 # clean prams | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 736 best_estimator_ = clean_params(best_estimator_) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 737 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 738 main_est = get_main_estimator(best_estimator_) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 739 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 740 if hasattr(main_est, "model_") and hasattr(main_est, "save_weights"): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 741 if outfile_weights: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 742 main_est.save_weights(outfile_weights) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 743 del main_est.model_ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 744 del main_est.fit_params | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 745 del main_est.model_class_ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 746 del main_est.validation_data | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 747 if getattr(main_est, "data_generator_", None): | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 748 del main_est.data_generator_ | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 749 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 750 with open(outfile_object, "wb") as output_handler: | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 751 print("Best estimator is saved: %s " % repr(best_estimator_)) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 752 pickle.dump(best_estimator_, output_handler, pickle.HIGHEST_PROTOCOL) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 753 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 754 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 755 if __name__ == "__main__": | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 756 aparser = argparse.ArgumentParser() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 757 aparser.add_argument("-i", "--inputs", dest="inputs", required=True) | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 758 aparser.add_argument("-e", "--estimator", dest="infile_estimator") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 759 aparser.add_argument("-X", "--infile1", dest="infile1") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 760 aparser.add_argument("-y", "--infile2", dest="infile2") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 761 aparser.add_argument("-O", "--outfile_result", dest="outfile_result") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 762 aparser.add_argument("-o", "--outfile_object", dest="outfile_object") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 763 aparser.add_argument("-w", "--outfile_weights", dest="outfile_weights") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 764 aparser.add_argument("-g", "--groups", dest="groups") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 765 aparser.add_argument("-r", "--ref_seq", dest="ref_seq") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 766 aparser.add_argument("-b", "--intervals", dest="intervals") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 767 aparser.add_argument("-t", "--targets", dest="targets") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 768 aparser.add_argument("-f", "--fasta_path", dest="fasta_path") | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 769 args = aparser.parse_args() | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 770 | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 771 main( | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 772 args.inputs, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 773 args.infile_estimator, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 774 args.infile1, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 775 args.infile2, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 776 args.outfile_result, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 777 outfile_object=args.outfile_object, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 778 outfile_weights=args.outfile_weights, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 779 groups=args.groups, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 780 ref_seq=args.ref_seq, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 781 intervals=args.intervals, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 782 targets=args.targets, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 783 fasta_path=args.fasta_path, | 
| 
59e8b4328c82
"planemo upload for repository https://github.com/bgruening/galaxytools/tree/master/tools/sklearn commit 208a8d348e7c7a182cfbe1b6f17868146428a7e2"
 bgruening parents: diff
changeset | 784 ) | 
