-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsvm-rbf-instrumentation.py
93 lines (79 loc) · 3.07 KB
/
svm-rbf-instrumentation.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#IMPORTS==============================================
import unittest
import json
import numpy as np
#Enable importing code from parent directory
import os, sys
p = os.path.abspath('..')
sys.path.insert(1, p)
from generateerrortensor import generateIncompleteErrorTensor
from trainmodels import evaluationFunctionGenerator, crossValidationFunctionGenerator
from loaddata import loadData, trainTestSplit, extractZeroOneClasses, convertZeroOne
from tensorcompletion import tensorcomplete_TMac_TT
from tensorcompletion import ket_augmentation, inverse_ket_augmentation
from tensorsearch import findBestValues, hyperparametersFromIndices
import regressionmetrics
import classificationmetrics
quantity = 'CPU-TIME'
known_fraction = 0.25
#Load dataset
task = 'classification'
data = loadData(source='sklearn', identifier='breast_cancer', task=task)
data_split = trainTestSplit(data, method = 'cross_validation')
budget_type = 'features'
budget_fraction = 0.5
func = crossValidationFunctionGenerator(data_split, algorithm='svm-rbf', task=task, budget_type=budget_type, budget_fraction=budget_fraction)
#Start timer/memory profiler/CPU timer
start_time = None
if quantity == 'EXEC-TIME':
import time
start_time = time.perf_counter_ns()
elif quantity == 'CPU-TIME':
import time
start_time = time.process_time_ns()
elif quantity == 'MAX-MEMORY':
import tracemalloc
tracemalloc.start()
#Generate range dictionary
ranges_dict = {
'C': {
'start': 0.05,
'end': 5.00,
'interval': 0.05,
},
'gamma': {
'start': 0.05,
'end': 5.00,
'interval': 0.05,
}
}
#Generate incomplete tensor
incomplete_tensor, known_indices = generateIncompleteErrorTensor(func, ranges_dict, known_fraction, metric=classificationmetrics.indicatorFunction, eval_trials=1)
print('TENSOR GENERATED')
expected_rank = [1]
#Apply tensor completion
predicted_tensor, _, _ = tensorcomplete_TMac_TT(incomplete_tensor, known_indices, expected_rank, convergence_tolerance=1e-15, iteration_limit=100000)
#Find best hyperparameter value
result = findBestValues(predicted_tensor, smallest=True, number_of_values=1)
values, indices = result['values'], result['indices']
hyperparameter_values = hyperparametersFromIndices(indices, ranges_dict)
#End timer/memory profiler/CPU timer
result = None
if quantity == 'EXEC-TIME':
end_time = time.perf_counter_ns()
result = end_time - start_time
elif quantity == 'CPU-TIME':
end_time = time.process_time_ns()
result = end_time - start_time
elif quantity == 'MAX-MEMORY':
_, result = tracemalloc.get_traced_memory()
tracemalloc.stop()
#Recreate cross-validation generator
data_split = trainTestSplit(data, method = 'cross_validation')
#Find the true loss for the selcted combination
truefunc = crossValidationFunctionGenerator(data_split, algorithm='svm-rbf', task=task)
true_value = truefunc(metric=classificationmetrics.indicatorFunction, **hyperparameter_values[0])
print(f'hyperparameters: {hyperparameter_values}')
print(f'function values: {values}')
print(f'True value: {true_value}')
print(f'{quantity}: {result}')