-
Notifications
You must be signed in to change notification settings - Fork 1
/
left_win.m
40 lines (35 loc) · 1.76 KB
/
left_win.m
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
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Function: I_z = left_win(S_x,S_y)
% Author: Rainer Storn
% Description: left_win(S_x,S_y) takes structures S_x and S_y as an argument.
% The function returns 1 if the left structure of the input structures,
% i.e. S_x, wins. If the right structure, S_y, wins, the result is 0.
% Parameters: S_x.I_nc (I) Number of constraints (must be the same for x and y).
% S_x.I_no (I) Number of objectives (must be the same for x and y).
% S_x.FVr_ca (I) Constraint array containing the constraint violation values.
% If the value is 0 the constraint is met. If it is > 0 it is
% still violated.
% S_x.FVr_oa (I) Objective array containing cost values which are supposed to be
% minimized.
% Return value: I_z (O) If S_x wins over S_y then I_z=1 else I_z=0.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function I_z = left_win(S_x,S_y);
I_z = 1; %start with I_z=1
%----deal with the constraints first. If constraints are not met------
%----S_x can't win.---------------------------------------------------
if (S_x.I_nc > 0)
for k=1:S_x.I_nc
if (S_x.FVr_ca(k) > 0) %if constraint is not yet met
if (S_x.FVr_ca(k) > S_y.FVr_ca(k))%if just one constraint of S_x is not improved
I_z = 0;
end
end
end
end
if (S_x.I_no > 0)
for k=1:S_x.I_no
if (S_x.FVr_oa(k) > S_y.FVr_oa(k))%if just one objective of S_x is less
I_z = 0;
end
end
end