diff options
Diffstat (limited to 'Solvers/VIATRA-Solver/hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra/src/hu/bme/mit/inf/dslreasoner/viatrasolver/logic2viatra/cardinality/MultiplicityGoalConstraintCalculator.xtend')
-rw-r--r-- | Solvers/VIATRA-Solver/hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra/src/hu/bme/mit/inf/dslreasoner/viatrasolver/logic2viatra/cardinality/MultiplicityGoalConstraintCalculator.xtend | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/Solvers/VIATRA-Solver/hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra/src/hu/bme/mit/inf/dslreasoner/viatrasolver/logic2viatra/cardinality/MultiplicityGoalConstraintCalculator.xtend b/Solvers/VIATRA-Solver/hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra/src/hu/bme/mit/inf/dslreasoner/viatrasolver/logic2viatra/cardinality/MultiplicityGoalConstraintCalculator.xtend new file mode 100644 index 00000000..034420d6 --- /dev/null +++ b/Solvers/VIATRA-Solver/hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra/src/hu/bme/mit/inf/dslreasoner/viatrasolver/logic2viatra/cardinality/MultiplicityGoalConstraintCalculator.xtend | |||
@@ -0,0 +1,65 @@ | |||
1 | package hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra.cardinality | ||
2 | |||
3 | import org.eclipse.emf.common.notify.Notifier | ||
4 | import org.eclipse.viatra.query.runtime.api.IQuerySpecification | ||
5 | import org.eclipse.viatra.query.runtime.api.ViatraQueryEngine | ||
6 | import org.eclipse.viatra.query.runtime.api.ViatraQueryMatcher | ||
7 | import org.eclipse.viatra.query.runtime.emf.EMFScope | ||
8 | |||
9 | class MultiplicityGoalConstraintCalculator { | ||
10 | val String targetRelationName | ||
11 | val IQuerySpecification<?> querySpecification | ||
12 | var ViatraQueryMatcher<?> matcher | ||
13 | val int minValue | ||
14 | val boolean containment | ||
15 | val int cost | ||
16 | |||
17 | public new(String targetRelationName, IQuerySpecification<?> querySpecification, int minValue, boolean containment, int cost) { | ||
18 | this.targetRelationName = targetRelationName | ||
19 | this.querySpecification = querySpecification | ||
20 | this.matcher = null | ||
21 | this.minValue = minValue | ||
22 | this.containment = containment | ||
23 | this.cost = cost | ||
24 | } | ||
25 | |||
26 | new(MultiplicityGoalConstraintCalculator other) { | ||
27 | this.targetRelationName = other.targetRelationName | ||
28 | this.querySpecification = other.querySpecification | ||
29 | this.matcher = null | ||
30 | this.minValue = other.minValue | ||
31 | this.containment = other.containment | ||
32 | this.cost = other.cost | ||
33 | } | ||
34 | |||
35 | def getName() { | ||
36 | targetRelationName | ||
37 | } | ||
38 | |||
39 | def isContainment() { | ||
40 | return containment | ||
41 | } | ||
42 | |||
43 | def init(Notifier notifier) { | ||
44 | val engine = ViatraQueryEngine.on(new EMFScope(notifier)) | ||
45 | matcher = querySpecification.getMatcher(engine) | ||
46 | } | ||
47 | |||
48 | def calculateValue() { | ||
49 | var res = 0 | ||
50 | val allMatches = this.matcher.allMatches | ||
51 | for(match : allMatches) { | ||
52 | val existingMultiplicity = match.get(4) as Integer | ||
53 | if(existingMultiplicity < this.minValue) { | ||
54 | val missingMultiplicity = this.minValue-existingMultiplicity | ||
55 | res += missingMultiplicity | ||
56 | } | ||
57 | // if(missingMultiplicity!=0) { | ||
58 | // println(targetRelationName+ " missing multiplicity: "+missingMultiplicity) | ||
59 | // } | ||
60 | } | ||
61 | // if(res>0) | ||
62 | // println(targetRelationName+ " all missing multiplicities: "+res + "*"+cost+"="+res*cost) | ||
63 | return res*cost | ||
64 | } | ||
65 | } | ||