forked from sustainable-computing-io/kepler-model-server
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathweight_model_request_test.py
More file actions
71 lines (60 loc) · 2.76 KB
/
weight_model_request_test.py
File metadata and controls
71 lines (60 loc) · 2.76 KB
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
#########################
# weight_mode_request.py
#
# This file covers the following cases.
# - getting weight from model server based on available features
#
#########################
import os
import sys
server_path = os.path.join(os.path.dirname(__file__), '../src')
util_path = os.path.join(os.path.dirname(__file__), '../src/util')
train_path = os.path.join(os.path.dirname(__file__), '../src/train')
estimate_path = os.path.join(os.path.dirname(__file__), '../src/estimate')
prom_path = os.path.join(os.path.dirname(__file__), '../src/train/prom')
sys.path.append(server_path)
sys.path.append(util_path)
sys.path.append(train_path)
sys.path.append(prom_path)
sys.path.append(estimate_path)
from train_types import FeatureGroups, FeatureGroup, ModelOutputType
from loader import get_download_output_path
from estimate.model_server_connector import list_all_models
from config import get_model_server_req_endpoint, download_path
from extractor_test import test_energy_source
from estimator_power_request_test import generate_request
os.environ['MODEL_SERVER_URL'] = 'http://localhost:8100'
import json
import time
import requests
weight_available_trainers = ["SGDRegressorTrainer"]
if __name__ == '__main__':
# test getting model from server
os.environ['MODEL_SERVER_ENABLE'] = "true"
energy_source = test_energy_source
available_models = list_all_models()
while len(available_models) == 0:
time.sleep(1)
print("wait for kepler model server response")
available_models = list_all_models()
for output_type_name, valid_fgs in available_models.items():
output_type = ModelOutputType[output_type_name]
output_path = get_download_output_path(download_path, energy_source, output_type)
for fg_name, best_model in valid_fgs.items():
for trainer in weight_available_trainers:
print("feature group: ", fg_name)
metrics = FeatureGroups[FeatureGroup[fg_name]]
request_json = generate_request(trainer, n=10, metrics=metrics, output_type=output_type_name)
request_json["metrics"] += request_json["system_features"]
request_json["weight"] = "true"
del request_json["system_features"]
del request_json["values"]
del request_json["system_values"]
try:
response = requests.post(get_model_server_req_endpoint(), json=request_json)
except Exception as err:
print("cannot get response from model server: {}".format(err))
sys.exit(1)
assert response.status_code == 200, "response {} not OK".format(request_json)
loaded_weight = json.loads(response.content)
print(loaded_weight)