-
Notifications
You must be signed in to change notification settings - Fork 3
/
config.py
161 lines (137 loc) · 5.49 KB
/
config.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
#!/usr/bin/env python
# ------------------------------------------------------------------------------------------------------%
# Created by "Thieu" at 15:15, 06/01/2021 %
# %
# Email: nguyenthieu2102@gmail.com %
# Homepage: https://www.researchgate.net/profile/Nguyen_Thieu2 %
# Github: https://github.com/thieu1995 %
# ------------------------------------------------------------------------------------------------------%
from os.path import abspath, dirname
basedir = abspath(dirname(__file__))
class Config:
CORE_DATA_DIR = f'{basedir}/data'
INPUT_DATA = f'{CORE_DATA_DIR}/input_data'
RESULTS_DATA = f'{CORE_DATA_DIR}/results_100loop'
MODE = 'epoch' # epoch, fe (function evaluation counter instead of epoch)
TIME_BOUND_KEY = False # time bound for the training process
TIME_BOUND_VALUE = 100
METRICS_MAX = ["weighting-min", ] # other methods need min - for calculate the global best fitness
METRICS_NEED_MIN_OBJECTIVE_VALUES = False # For tunning all parameter to find the min-objective value of each objective.
MULTI_OBJECTIVE_SUPPORTERS = ["BaseNSGA_II", "BaseNSGA_III", "BaseMO_SSA", "BaseMO_ALO", "BaseNS_SSA", "LSHADE"]
### Single Objective
# 1. power --> find Min
# 2. latency --> find Min
# 3. cost --> find Min
### Multiple Objective
## Single target
# 1. weighting --> find Min
# 2. distancing (demand-level vector) --> find Min
# 3. min-max formulation --> find Min
# 4. weighting-min formulation # the paper of Thang and Khiem --> find Max
## Multi-target
# 1. Pareto-front
## finally: metrics = ["power", "latency", "cost", "weighting", "distancing", "min-max", "weighting-min", "pareto",...]
METRICS = 'pareto'
OBJ_WEIGHTING_METRICS = [0.2, 0.3, 0.5]
OBJ_DISTANCING_METRICS = [800, 40000, 500] ## DEMAND-LEVEL REQUIREMENT
OBJ_MINMAX_METRICS = [800, 40000, 500]
OBJ_WEIGHTING_MIN_METRICS_1 = [0.2, 0.3, 0.5]
OBJ_WEIGHTING_MIN_METRICS_2 = [800, 40000, 500]
OBJ_NAME_1 = ["Power Consumption (Wh)", "Service Latency (s)", "Monetary Cost ($)"]
OBJ_NAME_2 = ["Power Consumption (Wh)", "Service Latency (s)"]
OBJ_NAME_3 = ["Power Consumption (Wh)", "Monetary Cost ($)"]
OBJ_NAME_4 = ["Service Latency (s)", "Monetary Cost ($)"]
OBJ_NAME_5 = ["Power Consumption (Wh)"]
OBJ_NAME_6 = ["Service Latency (s)"]
OBJ_NAME_7 = ["Monetary Cost ($)"]
VISUAL_FRONTS_COLORS = [u'#1f77b4', u'#ff7f0e', u'#2ca02c', u'#9467bd', u'#d62728', u'#8c564b', u'#e377c2', u'#7f7f7f', u'#bcbd22', u'#17becf']
# VISUAL_FRONTS_COLORS = ['black', 'limegreen', 'orange', 'darkblue', 'darkcyan', 'lightgreen', 'sandybrown', 'pink', 'red', 'darkviolet']
# VISUAL_FRONTS_COLORS = ['black', 'red', 'green', 'blue', 'orange', 'cyan', 'purple', 'pink', 'brown', 'yellow']
VISUAL_FRONTS_MARKERS = ["D", "1", "o", '*', "+", "x", "4", ">", "p", "s"]
VISUAL_SAVING = False
SAVE_TRAINING_RESULTS = True
class DefaultData:
R_PROCESSING_BOUND = [50_000, 500_000] # 100 KB - 1000 KB (0.1 - 1.0 MB)
R_STORAGE_BOUND = [50_000, 500_000]
Q_PROCESSING_BOUND = [50_000, 500_000]
Q_STORAGE_BOUND = [50_000, 500_000]
SERVICE_LATENCY_MAX = [10, 100] # 10 seconds to 100 seconds
TASK_LIST = list(range(50, 1001, 50))
TASK_LABEL_IMPORTANT = 1
TASK_DEFAULT_SL_MAX = 10
NUM_TASKS = 1000
NUM_CLOUDS = 2
NUM_FOGS = 8
NUM_PEERS = 5
LOC_LONG_BOUND = [-100, 100]
LOC_LAT_BOUND = [-100, 100]
RATE_FOG_CLOUD_LINKED = 1.0
RATE_FOG_PEER_LINKED = 2
RATE_CLOUD_PEER_LINKED = 2
class OptParas: # Optimizer parameters config
GA = {
"p_c": [0.9],
"p_m": [0.05]
}
PSO = {
"w_min": [0.4],
"w_max": [0.9],
"c_local": [1.2],
"c_global": [1.2]
}
WOA = { # This parameters are actually fixed parameters in WOA
"p": [0.5],
"b": [1.0]
}
EO = { # This parameters are actually fixed parameters in EO
"V": [1.0],
"a1": [2.0],
"a2": [1.0],
"GP": [0.5]
}
AEO = { # This algorithm has no actually parameters
"No": [None]
}
SSA = {
"ST": [0.8], # ST in [0.5, 1.0]
"PD": [0.2], # number of producers
"SD": [0.1] # number of sparrows who perceive the danger
}
### Multi-objectives
NSGA_II = {
"p_c": [0.9],
"p_m": [0.05]
}
NSGA_III = {
"p_c": [0.9],
"p_m": [0.05],
"cof_divs": [16],
"old_pop_rate": [0.7]
}
MO_SSA = {
"ST": [0.8],
"PD": [0.2],
"SD": [0.1]
}
MO_ALO = {
"No": [None]
}
class OptExp: # Optimizer paras in experiments
N_TRIALS = 10
N_TASKS = [50, 100, 150, 200, 250, 300, 350, 400, 450, 500]
TIME_BOUND_VALUES = [60, 100]
POP_SIZE = [50]
LB = [-1]
UB = [1]
EPOCH = [100]
FE = [100000]
VERBOSE = False
# N_TRIALS = 2
# N_TASKS = [50, 100]
# TIME_BOUND_VALUES = [60]
# POP_SIZE = [50]
# LB = [-1]
# UB = [1]
# EPOCH = [3]
# FE = [100000]
# VERBOSE = True