forked from ncclab-sustech/MOVEA
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtdcs_problem.py
51 lines (47 loc) · 1.51 KB
/
tdcs_problem.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
import numpy as np
from public import glo
import geatpy as ea
from public import util
NUM_ELE = glo.NUM_ELE
class MyProblem(ea.Problem):
def __init__(self):
name = 'MyProblem'
M = 1
maxormins = [1]
self.var_set = np.arange(0,NUM_ELE,1)
Dim = 4
varTypes = [1] * Dim
lb = [0, 0,0,0]
ub = [(NUM_ELE-1), (NUM_ELE-1),(NUM_ELE-1),(NUM_ELE-1)]
lbin = [1] * Dim
ubin = [1] * Dim
ea.Problem.__init__(self,
name,
M,
maxormins,
Dim,
varTypes,
lb,
ub,
lbin,
ubin)
def evalVars(self, Vars):
Vars = Vars.astype(np.int32)
x1 = self.var_set[Vars[:, [0]]]
x2 = self.var_set[Vars[:, [1]]]
x3 = self.var_set[Vars[:, [2]]]
x4 = self.var_set[Vars[:, [3]]]
r = np.zeros(len(x1)).tolist()
for i in range(len(x1)):
lst = [int(x1[i]),int(x2[i]),int(x3[i]),int(x4[i])]
set_lst = set(lst)
if len(set_lst) == len(lst):
x = np.zeros(NUM_ELE)
x[x1[i]] = 1
x[x2[i]] = 1
x[x3[i]] = -1
x[x4[i]] = -1
r[i] = [util.tdcs_function1(x)]
else:
r[i] = [10000]
return np.array(r)