diff options
Diffstat (limited to 'subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/refinement/RefinementBasedInitializer.java')
-rw-r--r-- | subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/refinement/RefinementBasedInitializer.java | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/refinement/RefinementBasedInitializer.java b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/refinement/RefinementBasedInitializer.java new file mode 100644 index 00000000..b6bccb01 --- /dev/null +++ b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/refinement/RefinementBasedInitializer.java | |||
@@ -0,0 +1,34 @@ | |||
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.refinement; | ||
7 | |||
8 | import tools.refinery.store.model.Model; | ||
9 | import tools.refinery.store.reasoning.ReasoningAdapter; | ||
10 | import tools.refinery.store.reasoning.representation.PartialSymbol; | ||
11 | import tools.refinery.store.reasoning.seed.ModelSeed; | ||
12 | |||
13 | public class RefinementBasedInitializer<A, C> implements PartialModelInitializer { | ||
14 | private final PartialSymbol<A, C> partialSymbol; | ||
15 | |||
16 | public RefinementBasedInitializer(PartialSymbol<A, C> partialSymbol) { | ||
17 | this.partialSymbol = partialSymbol; | ||
18 | } | ||
19 | |||
20 | @Override | ||
21 | public void initialize(Model model, ModelSeed modelSeed) { | ||
22 | var refiner = model.getAdapter(ReasoningAdapter.class).getRefiner(partialSymbol); | ||
23 | var defaultValue = partialSymbol.abstractDomain().unknown(); | ||
24 | var cursor = modelSeed.getCursor(partialSymbol, defaultValue); | ||
25 | while (cursor.move()) { | ||
26 | var key = cursor.getKey(); | ||
27 | var value = cursor.getValue(); | ||
28 | if (!refiner.merge(key, value)) { | ||
29 | throw new IllegalArgumentException("Failed to merge value %s for key %s into %s" | ||
30 | .formatted(value, key, partialSymbol)); | ||
31 | } | ||
32 | } | ||
33 | } | ||
34 | } | ||