diff options
Diffstat (limited to 'subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/crossreference/CrossReferenceUtils.java')
-rw-r--r-- | subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/crossreference/CrossReferenceUtils.java | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/crossreference/CrossReferenceUtils.java b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/crossreference/CrossReferenceUtils.java new file mode 100644 index 00000000..c4a2f2b3 --- /dev/null +++ b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/crossreference/CrossReferenceUtils.java | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * SPDX-FileCopyrightText: 2023 The Refinery Authors <https://refinery.tools/> | ||
3 | * | ||
4 | * SPDX-License-Identifier: EPL-2.0 | ||
5 | */ | ||
6 | package tools.refinery.store.reasoning.translator.crossreference; | ||
7 | |||
8 | import tools.refinery.store.query.dnf.Query; | ||
9 | import tools.refinery.store.query.dnf.RelationalQuery; | ||
10 | import tools.refinery.store.query.literal.Literal; | ||
11 | import tools.refinery.store.query.term.NodeVariable; | ||
12 | import tools.refinery.store.query.term.Variable; | ||
13 | import tools.refinery.store.reasoning.literal.CountLowerBoundLiteral; | ||
14 | import tools.refinery.store.reasoning.representation.PartialRelation; | ||
15 | import tools.refinery.store.reasoning.translator.multiplicity.Multiplicity; | ||
16 | import tools.refinery.store.representation.cardinality.FiniteUpperCardinality; | ||
17 | |||
18 | import java.util.ArrayList; | ||
19 | import java.util.List; | ||
20 | |||
21 | import static tools.refinery.store.query.literal.Literals.check; | ||
22 | import static tools.refinery.store.query.term.int_.IntTerms.constant; | ||
23 | import static tools.refinery.store.query.term.int_.IntTerms.less; | ||
24 | import static tools.refinery.store.reasoning.literal.PartialLiterals.may; | ||
25 | |||
26 | class CrossReferenceUtils { | ||
27 | private CrossReferenceUtils() { | ||
28 | throw new IllegalStateException("This is a static utility class and should not be instantiated directly"); | ||
29 | } | ||
30 | |||
31 | public static RelationalQuery createMayHelper(PartialRelation linkType, PartialRelation type, | ||
32 | Multiplicity multiplicity, boolean inverse) { | ||
33 | String name; | ||
34 | NodeVariable variable; | ||
35 | List<Variable> arguments; | ||
36 | if (inverse) { | ||
37 | name = "Target"; | ||
38 | variable = Variable.of("target"); | ||
39 | arguments = List.of(Variable.of("source"), variable); | ||
40 | } else { | ||
41 | name = "Source"; | ||
42 | variable = Variable.of("source"); | ||
43 | arguments = List.of(variable, Variable.of("target")); | ||
44 | } | ||
45 | var builder = Query.builder(linkType.name() + "#mayNew" + name); | ||
46 | builder.parameter(variable); | ||
47 | var literals = new ArrayList<Literal>(); | ||
48 | literals.add(may(type.call(variable))); | ||
49 | if (multiplicity.multiplicity().upperBound() instanceof FiniteUpperCardinality finiteUpperCardinality) { | ||
50 | var existingLinks = Variable.of("existingLinks", Integer.class); | ||
51 | literals.add(new CountLowerBoundLiteral(existingLinks, linkType, arguments)); | ||
52 | literals.add(check(less(existingLinks, constant(finiteUpperCardinality.finiteUpperBound())))); | ||
53 | } | ||
54 | builder.clause(literals); | ||
55 | return builder.build(); | ||
56 | } | ||
57 | } | ||