|
|
@ -67,6 +67,14 @@ cors = CORS(app, resources={r"/data/*": {"origins": "*"}}) |
|
|
|
def Reset(): |
|
|
|
def Reset(): |
|
|
|
global DataRawLength |
|
|
|
global DataRawLength |
|
|
|
global DataResultsRaw |
|
|
|
global DataResultsRaw |
|
|
|
|
|
|
|
global previousState |
|
|
|
|
|
|
|
previousState = [] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global keySpecInternal |
|
|
|
|
|
|
|
keySpecInternal = 1 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global previousStateActive |
|
|
|
|
|
|
|
previousStateActive = [] |
|
|
|
|
|
|
|
|
|
|
|
global RANDOM_SEED |
|
|
|
global RANDOM_SEED |
|
|
|
RANDOM_SEED = 42 |
|
|
|
RANDOM_SEED = 42 |
|
|
@ -86,6 +94,9 @@ def Reset(): |
|
|
|
global AdaBModelsCount |
|
|
|
global AdaBModelsCount |
|
|
|
global GradBModelsCount |
|
|
|
global GradBModelsCount |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global keyData |
|
|
|
|
|
|
|
keyData = 0 |
|
|
|
|
|
|
|
|
|
|
|
KNNModelsCount = 0 |
|
|
|
KNNModelsCount = 0 |
|
|
|
SVCModelsCount = 576 |
|
|
|
SVCModelsCount = 576 |
|
|
|
GausNBModelsCount = 736 |
|
|
|
GausNBModelsCount = 736 |
|
|
@ -168,12 +179,24 @@ def RetrieveFileName(): |
|
|
|
|
|
|
|
|
|
|
|
fileName = request.get_data().decode('utf8').replace("'", '"') |
|
|
|
fileName = request.get_data().decode('utf8').replace("'", '"') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global keySpecInternal |
|
|
|
|
|
|
|
keySpecInternal = 1 |
|
|
|
|
|
|
|
|
|
|
|
global RANDOM_SEED |
|
|
|
global RANDOM_SEED |
|
|
|
RANDOM_SEED = 42 |
|
|
|
RANDOM_SEED = 42 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global keyData |
|
|
|
|
|
|
|
keyData = 0 |
|
|
|
|
|
|
|
|
|
|
|
global XData |
|
|
|
global XData |
|
|
|
XData = [] |
|
|
|
XData = [] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global previousState |
|
|
|
|
|
|
|
previousState = [] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global previousStateActive |
|
|
|
|
|
|
|
previousStateActive = [] |
|
|
|
|
|
|
|
|
|
|
|
global yData |
|
|
|
global yData |
|
|
|
yData = [] |
|
|
|
yData = [] |
|
|
|
|
|
|
|
|
|
|
@ -1686,9 +1709,10 @@ def RetrieveSelClassifiersID(): |
|
|
|
ComputeMetricsForSel(ClassifierIDsList) |
|
|
|
ComputeMetricsForSel(ClassifierIDsList) |
|
|
|
ClassifierIDCleaned = json.loads(ClassifierIDsList) |
|
|
|
ClassifierIDCleaned = json.loads(ClassifierIDsList) |
|
|
|
|
|
|
|
|
|
|
|
global keySpec |
|
|
|
global keySpecInternal |
|
|
|
keySpec = ClassifierIDCleaned['keyNow'] |
|
|
|
keySpecInternal = 1 |
|
|
|
print(keySpec) |
|
|
|
keySpecInternal = ClassifierIDCleaned['keyNow'] |
|
|
|
|
|
|
|
|
|
|
|
EnsembleModel(ClassifierIDsList, 1) |
|
|
|
EnsembleModel(ClassifierIDsList, 1) |
|
|
|
return 'Everything Okay' |
|
|
|
return 'Everything Okay' |
|
|
|
|
|
|
|
|
|
|
@ -2429,6 +2453,11 @@ def FeatureSelPerModel(): |
|
|
|
|
|
|
|
|
|
|
|
def EnsembleModel(Models, keyRetrieved): |
|
|
|
def EnsembleModel(Models, keyRetrieved): |
|
|
|
global scores |
|
|
|
global scores |
|
|
|
|
|
|
|
global previousState |
|
|
|
|
|
|
|
global previousStateActive |
|
|
|
|
|
|
|
global keySpec |
|
|
|
|
|
|
|
global keySpecInternal |
|
|
|
|
|
|
|
global keyData |
|
|
|
scores = [] |
|
|
|
scores = [] |
|
|
|
|
|
|
|
|
|
|
|
global all_classifiersSelection |
|
|
|
global all_classifiersSelection |
|
|
@ -2581,9 +2610,6 @@ def EnsembleModel(Models, keyRetrieved): |
|
|
|
arg = dfParamGradBFilt[eachelem-GradBModelsCount] |
|
|
|
arg = dfParamGradBFilt[eachelem-GradBModelsCount] |
|
|
|
all_classifiers.append(make_pipeline(ColumnSelector(cols=columnsInit), GradientBoostingClassifier(random_state=RANDOM_SEED).set_params(**arg))) |
|
|
|
all_classifiers.append(make_pipeline(ColumnSelector(cols=columnsInit), GradientBoostingClassifier(random_state=RANDOM_SEED).set_params(**arg))) |
|
|
|
|
|
|
|
|
|
|
|
global sclfStack |
|
|
|
|
|
|
|
sclfStack = 0 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
global sclf |
|
|
|
global sclf |
|
|
|
sclf = 0 |
|
|
|
sclf = 0 |
|
|
|
sclf = StackingCVClassifier(classifiers=all_classifiers, |
|
|
|
sclf = StackingCVClassifier(classifiers=all_classifiers, |
|
|
@ -2591,11 +2617,10 @@ def EnsembleModel(Models, keyRetrieved): |
|
|
|
meta_classifier=lr, |
|
|
|
meta_classifier=lr, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
n_jobs = -1) |
|
|
|
n_jobs = -1) |
|
|
|
sclfStack = sclf |
|
|
|
keySpec = 0 |
|
|
|
elif (keyRetrieved == 1): |
|
|
|
elif (keyRetrieved == 1): |
|
|
|
Models = json.loads(Models) |
|
|
|
Models = json.loads(Models) |
|
|
|
ModelsAll = preProceModels() |
|
|
|
ModelsAll = preProceModels() |
|
|
|
global keySpec |
|
|
|
|
|
|
|
for index, modHere in enumerate(ModelsAll): |
|
|
|
for index, modHere in enumerate(ModelsAll): |
|
|
|
flag = 0 |
|
|
|
flag = 0 |
|
|
|
for loop in Models['ClassifiersList']: |
|
|
|
for loop in Models['ClassifiersList']: |
|
|
@ -2609,11 +2634,8 @@ def EnsembleModel(Models, keyRetrieved): |
|
|
|
meta_classifier=lr, |
|
|
|
meta_classifier=lr, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
n_jobs = -1) |
|
|
|
n_jobs = -1) |
|
|
|
print('mpike') |
|
|
|
keySpec = 1 |
|
|
|
if (keySpec == 0): |
|
|
|
|
|
|
|
sclfStack = sclf |
|
|
|
|
|
|
|
elif (keyRetrieved == 2): |
|
|
|
elif (keyRetrieved == 2): |
|
|
|
# fix this part! |
|
|
|
|
|
|
|
if (len(all_classifiersSelection) == 0): |
|
|
|
if (len(all_classifiersSelection) == 0): |
|
|
|
all_classifiers = [] |
|
|
|
all_classifiers = [] |
|
|
|
columnsInit = [] |
|
|
|
columnsInit = [] |
|
|
@ -2769,22 +2791,25 @@ def EnsembleModel(Models, keyRetrieved): |
|
|
|
meta_classifier=lr, |
|
|
|
meta_classifier=lr, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
n_jobs = -1) |
|
|
|
n_jobs = -1) |
|
|
|
|
|
|
|
keySpec = 1 |
|
|
|
else: |
|
|
|
else: |
|
|
|
Models = json.loads(Models) |
|
|
|
keySpec = 2 |
|
|
|
ModelsAll = preProceModels() |
|
|
|
|
|
|
|
for index, modHere in enumerate(ModelsAll): |
|
|
|
# Models = json.loads(Models) |
|
|
|
flag = 0 |
|
|
|
# ModelsAll = preProceModels() |
|
|
|
for loop in Models['ClassifiersList']: |
|
|
|
# for index, modHere in enumerate(ModelsAll): |
|
|
|
if (int(loop) == int(modHere)): |
|
|
|
# flag = 0 |
|
|
|
flag = 1 |
|
|
|
# for loop in Models['ClassifiersList']: |
|
|
|
if (flag is 1): |
|
|
|
# if (int(loop) == int(modHere)): |
|
|
|
all_classifiersSelection.append(all_classifiers[index]) |
|
|
|
# flag = 1 |
|
|
|
|
|
|
|
# if (flag is 1): |
|
|
|
sclfStack = StackingCVClassifier(classifiers=all_classifiersSelection, |
|
|
|
# all_classifiersSelection.append(all_classifiers[index]) |
|
|
|
use_probas=True, |
|
|
|
|
|
|
|
meta_classifier=lr, |
|
|
|
# sclfStack = StackingCVClassifier(classifiers=all_classifiersSelection, |
|
|
|
random_state=RANDOM_SEED, |
|
|
|
# use_probas=True, |
|
|
|
n_jobs = -1) |
|
|
|
# meta_classifier=lr, |
|
|
|
|
|
|
|
# random_state=RANDOM_SEED, |
|
|
|
|
|
|
|
# n_jobs = -1) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#else: |
|
|
|
#else: |
|
|
@ -2803,24 +2828,134 @@ def EnsembleModel(Models, keyRetrieved): |
|
|
|
# random_state=RANDOM_SEED, |
|
|
|
# random_state=RANDOM_SEED, |
|
|
|
# n_jobs = -1) |
|
|
|
# n_jobs = -1) |
|
|
|
|
|
|
|
|
|
|
|
if (keyRetrieved == 0): |
|
|
|
# if (keyRetrieved == 0): |
|
|
|
pass |
|
|
|
# pass |
|
|
|
else: |
|
|
|
# else: |
|
|
|
|
|
|
|
print(keySpec) |
|
|
|
|
|
|
|
print(keySpecInternal) |
|
|
|
|
|
|
|
if (keySpec == 0 or keySpec == 1): |
|
|
|
num_cores = multiprocessing.cpu_count() |
|
|
|
num_cores = multiprocessing.cpu_count() |
|
|
|
inputsSc = ['accuracy','precision_weighted','recall_weighted','accuracy','precision_weighted','recall_weighted','f1_weighted','f1_weighted'] |
|
|
|
inputsSc = ['accuracy','precision_weighted','recall_weighted','f1_weighted'] |
|
|
|
flat_results = Parallel(n_jobs=num_cores)(delayed(solve)(sclf,sclfStack,XData,yData,crossValidation,item,index) for index, item in enumerate(inputsSc)) |
|
|
|
|
|
|
|
|
|
|
|
flat_results = Parallel(n_jobs=num_cores)(delayed(solve)(sclf,keyData,keySpec,keySpecInternal,previousState,previousStateActive,XData,yData,crossValidation,item,index) for index, item in enumerate(inputsSc)) |
|
|
|
scores = [item for sublist in flat_results for item in sublist] |
|
|
|
scores = [item for sublist in flat_results for item in sublist] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (keySpec == 0): |
|
|
|
|
|
|
|
previousState = [] |
|
|
|
|
|
|
|
previousState.append(scores[2]) |
|
|
|
|
|
|
|
previousState.append(scores[3]) |
|
|
|
|
|
|
|
previousState.append(scores[6]) |
|
|
|
|
|
|
|
previousState.append(scores[7]) |
|
|
|
|
|
|
|
previousState.append(scores[10]) |
|
|
|
|
|
|
|
previousState.append(scores[11]) |
|
|
|
|
|
|
|
previousState.append(scores[14]) |
|
|
|
|
|
|
|
previousState.append(scores[15]) |
|
|
|
|
|
|
|
elif (keySpec == 1): |
|
|
|
|
|
|
|
if (keySpecInternal == 1): |
|
|
|
|
|
|
|
previousStateActive = [] |
|
|
|
|
|
|
|
previousStateActive.append(scores[0]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[1]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[4]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[5]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[8]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[9]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[12]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[13]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
previousStateActive = [] |
|
|
|
|
|
|
|
previousStateActive.append(scores[0]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[1]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[4]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[5]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[8]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[9]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[12]) |
|
|
|
|
|
|
|
previousStateActive.append(scores[13]) |
|
|
|
|
|
|
|
previousState = [] |
|
|
|
|
|
|
|
previousState.append(scores[2]) |
|
|
|
|
|
|
|
previousState.append(scores[3]) |
|
|
|
|
|
|
|
previousState.append(scores[6]) |
|
|
|
|
|
|
|
previousState.append(scores[7]) |
|
|
|
|
|
|
|
previousState.append(scores[10]) |
|
|
|
|
|
|
|
previousState.append(scores[11]) |
|
|
|
|
|
|
|
previousState.append(scores[14]) |
|
|
|
|
|
|
|
previousState.append(scores[15]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
scores = [] |
|
|
|
|
|
|
|
previousState = [] |
|
|
|
|
|
|
|
scores.append(previousStateActive[0]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[1]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[0]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[1]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[0]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[1]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[2]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[3]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[2]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[3]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[2]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[3]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[4]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[5]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[4]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[5]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[4]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[5]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[6]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[7]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[6]) |
|
|
|
|
|
|
|
scores.append(previousStateActive[7]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[6]) |
|
|
|
|
|
|
|
previousState.append(previousStateActive[7]) |
|
|
|
|
|
|
|
|
|
|
|
return 'Okay' |
|
|
|
return 'Okay' |
|
|
|
|
|
|
|
|
|
|
|
def solve(sclf,sclfStack,XData,yData,crossValidation,scoringIn,loop): |
|
|
|
def solve(sclf,keyData,keySpec,keySpecInternal,previousStateLoc,previousStateActiveLoc,XData,yData,crossValidation,scoringIn,loop): |
|
|
|
scoresLoc = [] |
|
|
|
scoresLoc = [] |
|
|
|
if (loop < 3): |
|
|
|
if (keySpec == 0): |
|
|
|
temp = model_selection.cross_val_score(sclf, XData, yData, cv=crossValidation, scoring=scoringIn, n_jobs=-1) |
|
|
|
temp = model_selection.cross_val_score(sclf, XData, yData, cv=crossValidation, scoring=scoringIn, n_jobs=-1) |
|
|
|
|
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
|
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
|
|
|
|
if (keyData == 1): |
|
|
|
|
|
|
|
if (loop == 0): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[0]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[1]) |
|
|
|
|
|
|
|
elif (loop == 1): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[2]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[3]) |
|
|
|
|
|
|
|
elif (loop == 2): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[4]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[5]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[6]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[7]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
|
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
else: |
|
|
|
else: |
|
|
|
temp = model_selection.cross_val_score(sclfStack, XData, yData, cv=crossValidation, scoring=scoringIn, n_jobs=-1) |
|
|
|
if (keySpecInternal == 1): |
|
|
|
|
|
|
|
temp = model_selection.cross_val_score(sclf, XData, yData, cv=crossValidation, scoring=scoringIn, n_jobs=-1) |
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
|
|
|
|
if (loop == 0): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[0]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[1]) |
|
|
|
|
|
|
|
elif (loop == 1): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[2]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[3]) |
|
|
|
|
|
|
|
elif (loop == 2): |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[4]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[5]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[6]) |
|
|
|
|
|
|
|
scoresLoc.append(previousStateLoc[7]) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
temp = model_selection.cross_val_score(sclf, XData, yData, cv=crossValidation, scoring=scoringIn, n_jobs=-1) |
|
|
|
|
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
|
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
|
|
|
|
scoresLoc.append(temp.mean()) |
|
|
|
|
|
|
|
scoresLoc.append(temp.std()) |
|
|
|
|
|
|
|
|
|
|
|
return scoresLoc |
|
|
|
return scoresLoc |
|
|
|
|
|
|
|
|
|
|
|
# Sending the final results to be visualized as a line plot |
|
|
|
# Sending the final results to be visualized as a line plot |
|
|
@ -2856,6 +2991,8 @@ def RetrieveFilter(): |
|
|
|
def RetrieveDataSpacePoints(): |
|
|
|
def RetrieveDataSpacePoints(): |
|
|
|
dataSpacePoints = request.get_data().decode('utf8').replace("'", '"') |
|
|
|
dataSpacePoints = request.get_data().decode('utf8').replace("'", '"') |
|
|
|
dataSpacePointsCleared = json.loads(dataSpacePoints) |
|
|
|
dataSpacePointsCleared = json.loads(dataSpacePoints) |
|
|
|
|
|
|
|
global keyData |
|
|
|
|
|
|
|
keyData = 1 |
|
|
|
global dataSpacePointsIDs |
|
|
|
global dataSpacePointsIDs |
|
|
|
dataSpacePointsIDs = dataSpacePointsCleared['points'] |
|
|
|
dataSpacePointsIDs = dataSpacePointsCleared['points'] |
|
|
|
return 'Done' |
|
|
|
return 'Done' |
|
|
|