blob: 34f73952998eb2d18d954e7c735b0fe3590de015 (
plain) (
blame)
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
|
package hu.bme.mit.inf.dslreasoner.domains.cps.mdeo;
import com.google.common.base.Objects;
import hu.bme.mit.inf.dslreasoner.domains.cps.ApplicationInstance;
import hu.bme.mit.inf.dslreasoner.domains.cps.ApplicationType;
import hu.bme.mit.inf.dslreasoner.domains.cps.CyberPhysicalSystem;
import hu.bme.mit.inf.dslreasoner.domains.cps.Request;
import hu.bme.mit.inf.dslreasoner.domains.cps.Requirement;
import org.eclipse.emf.common.util.EList;
import org.eclipse.emf.ecore.EObject;
import uk.ac.kcl.inf.mdeoptimiser.libraries.core.optimisation.IGuidanceFunction;
import uk.ac.kcl.inf.mdeoptimiser.libraries.core.optimisation.interpreter.guidance.Solution;
@SuppressWarnings("all")
public class NotSatisfiedRequirementsConstraint implements IGuidanceFunction {
@Override
public String getName() {
return "NotSatisfiedRequirements";
}
@Override
public double computeFitness(final Solution solution) {
int _xblockexpression = (int) 0;
{
EObject _model = solution.getModel();
final CyberPhysicalSystem cps = ((CyberPhysicalSystem) _model);
int cost = 0;
EList<Request> _requests = cps.getRequests();
for (final Request request : _requests) {
EList<Requirement> _requirements = request.getRequirements();
for (final Requirement requirement : _requirements) {
{
int _cost = cost;
int _count = requirement.getCount();
int _size = requirement.getInstances().size();
int _minus = (_count - _size);
int _abs = Math.abs(_minus);
cost = (_cost + _abs);
EList<ApplicationInstance> _instances = requirement.getInstances();
for (final ApplicationInstance app : _instances) {
ApplicationType _type = app.getType();
ApplicationType _type_1 = requirement.getType();
boolean _notEquals = (!Objects.equal(_type, _type_1));
if (_notEquals) {
cost++;
}
}
}
}
}
_xblockexpression = cost;
}
return _xblockexpression;
}
}
|