diff options
Diffstat (limited to 'subprojects/viatra-runtime-localsearch/src/main/java/tools/refinery/viatra/runtime/localsearch/matcher/integration/IAdornmentProvider.java')
-rw-r--r-- | subprojects/viatra-runtime-localsearch/src/main/java/tools/refinery/viatra/runtime/localsearch/matcher/integration/IAdornmentProvider.java | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/subprojects/viatra-runtime-localsearch/src/main/java/tools/refinery/viatra/runtime/localsearch/matcher/integration/IAdornmentProvider.java b/subprojects/viatra-runtime-localsearch/src/main/java/tools/refinery/viatra/runtime/localsearch/matcher/integration/IAdornmentProvider.java new file mode 100644 index 00000000..86058be0 --- /dev/null +++ b/subprojects/viatra-runtime-localsearch/src/main/java/tools/refinery/viatra/runtime/localsearch/matcher/integration/IAdornmentProvider.java | |||
@@ -0,0 +1,72 @@ | |||
1 | /******************************************************************************* | ||
2 | * Copyright (c) 2010-2016, Grill Balázs, IncQueryLabs Ltd. | ||
3 | * This program and the accompanying materials are made available under the | ||
4 | * terms of the Eclipse Public License v. 2.0 which is available at | ||
5 | * http://www.eclipse.org/legal/epl-v20.html. | ||
6 | * | ||
7 | * SPDX-License-Identifier: EPL-2.0 | ||
8 | *******************************************************************************/ | ||
9 | package tools.refinery.viatra.runtime.localsearch.matcher.integration; | ||
10 | |||
11 | import java.util.Collections; | ||
12 | import java.util.Set; | ||
13 | |||
14 | import tools.refinery.viatra.runtime.matchers.backend.QueryEvaluationHint; | ||
15 | import tools.refinery.viatra.runtime.matchers.backend.QueryEvaluationHint.BackendRequirement; | ||
16 | import tools.refinery.viatra.runtime.matchers.psystem.queries.PParameter; | ||
17 | import tools.refinery.viatra.runtime.matchers.psystem.queries.PQuery; | ||
18 | |||
19 | /** | ||
20 | * An adornment provider is used to define the adornments the pattern matcher should prepare for. | ||
21 | * | ||
22 | * <p>A default implementation is available in {@link AllValidAdornments} that describes all | ||
23 | * adornments fulfilling the parameter direction declarations; | ||
24 | * another default option (with better performance but restricted applicability) is {@link LazyPlanningAdornments}. | ||
25 | * | ||
26 | * <br><br> | ||
27 | * | ||
28 | * Users may implement this interface to limit the number of prepared plans based on some runtime information: | ||
29 | * | ||
30 | * <pre> | ||
31 | * class SomeAdornments{ | ||
32 | * | ||
33 | * public Iterable<Set<{@link PParameter}>> getAdornments({@link PQuery} query){ | ||
34 | * if (SomeGeneratedQuerySpecification.instance().getInternalQueryRepresentation().equals(query)){ | ||
35 | * return Collections.singleton(Sets.filter(Sets.newHashSet(query.getParameters()), new Predicate<PParameter>() { | ||
36 | * | ||
37 | * @Override | ||
38 | * public boolean apply(PParameter input) { | ||
39 | * // Decide whether this particular parameter will be bound | ||
40 | * return false; | ||
41 | * } | ||
42 | * })); | ||
43 | * } | ||
44 | * // Returning an empty iterable is safe for unknown queries | ||
45 | * return Collections.emptySet(); | ||
46 | * } | ||
47 | * | ||
48 | * } | ||
49 | * </pre> | ||
50 | * | ||
51 | * @author Grill Balázs | ||
52 | * @since 1.5 | ||
53 | * | ||
54 | */ | ||
55 | public interface IAdornmentProvider { | ||
56 | |||
57 | /** | ||
58 | * The bound parameter sets | ||
59 | */ | ||
60 | public Iterable<Set<PParameter>> getAdornments(PQuery query); | ||
61 | |||
62 | /** | ||
63 | * @return a simple hint that only overrides the adornment provider | ||
64 | * @since 2.1 | ||
65 | */ | ||
66 | public static QueryEvaluationHint toHint(IAdornmentProvider adornmentProvider) { | ||
67 | return new QueryEvaluationHint( | ||
68 | Collections.singletonMap(LocalSearchHintOptions.ADORNMENT_PROVIDER, adornmentProvider), | ||
69 | BackendRequirement.UNSPECIFIED); | ||
70 | } | ||
71 | |||
72 | } | ||