Interface EvaluationStrategy
- 
- All Superinterfaces:
- FederatedServiceResolver
 - All Known Implementing Classes:
- DefaultEvaluationStrategy,- EvaluationStrategyImpl,- ExtendedEvaluationStrategy,- FederationEvalStrategy,- LimitedSizeEvaluationStrategy,- SailFederationEvalStrategy,- SimpleEvaluationStrategy,- SparqlFederationEvalStrategy,- StrictEvaluationStrategy,- TupleFunctionEvaluationStrategy
 
 public interface EvaluationStrategy extends FederatedServiceResolver - Author:
- Arjohn Kampman, James Leigh
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description CloseableIteration<BindingSet,QueryEvaluationException>evaluate(Service expr, String serviceUri, CloseableIteration<BindingSet,QueryEvaluationException> bindings)Evaluates the tuple expression against the supplied triple source with the specified set of variable bindings as input.CloseableIteration<BindingSet,QueryEvaluationException>evaluate(TupleExpr expr, BindingSet bindings)Evaluates the tuple expression against the supplied triple source with the specified set of variable bindings as input.Valueevaluate(ValueExpr expr, BindingSet bindings)Gets the value of this expression.QueryEvaluationModegetQueryEvaluationMode()FederatedServicegetService(String serviceUrl)Retrieve theFederatedServiceregistered for serviceUrl.default booleanisTrackResultSize()Enable or disable results size tracking for the query plan.booleanisTrue(QueryValueEvaluationStep expr, BindingSet bindings)booleanisTrue(ValueExpr expr, BindingSet bindings)Evaluates the boolean expression on the supplied TripleSource object.default <T> Queue<T>makeQueue()default <T> Set<T>makeSet()TupleExproptimize(TupleExpr expr, EvaluationStatistics evaluationStatistics, BindingSet bindings)Execute theQueryOptimizerPipelineon the givenTupleExprto optimize its execution plan.default QueryEvaluationStepprecompile(TupleExpr expr)Prepare a QueryEvaluationStep that tries to do as much work once per query avoiding repeated calls to the same code as much as possible.default QueryEvaluationStepprecompile(TupleExpr expr, QueryEvaluationContext context)default QueryValueEvaluationStepprecompile(ValueExpr arg, QueryEvaluationContext context)voidsetOptimizerPipeline(QueryOptimizerPipeline pipeline)Set theQueryOptimizerPipelineto use for optimizing any incoming queries.voidsetQueryEvaluationMode(QueryEvaluationMode queryEvaluationMode)default voidsetTrackResultSize(boolean trackResultSize)Enable or disable results size tracking for the query plan.default voidsetTrackTime(boolean trackTime)Enable or disable time tracking for the query plan.
 
- 
- 
- 
Method Detail- 
getServiceFederatedService getService(String serviceUrl) throws QueryEvaluationException Retrieve theFederatedServiceregistered for serviceUrl. If there is no service registered for serviceUrl, a newSPARQLFederatedServiceis created and registered.- Specified by:
- getServicein interface- FederatedServiceResolver
- Parameters:
- serviceUrl- URL of the service.
- Returns:
- the FederatedServiceregistered for the serviceUrl.
- Throws:
- QueryEvaluationException
- See Also:
- FederatedServiceResolver.getService(java.lang.String)
 
 - 
setOptimizerPipelinevoid setOptimizerPipeline(QueryOptimizerPipeline pipeline) Set theQueryOptimizerPipelineto use for optimizing any incoming queries.- Parameters:
- pipeline- the- QueryOptimizerPipeline.
- Since:
- 3.0
- See Also:
- optimize(TupleExpr, EvaluationStatistics, BindingSet)
 
 - 
optimizeTupleExpr optimize(TupleExpr expr, EvaluationStatistics evaluationStatistics, BindingSet bindings) Execute theQueryOptimizerPipelineon the givenTupleExprto optimize its execution plan.- Parameters:
- expr- the- TupleExprto optimize.
- evaluationStatistics- the- EvaluationStatisticsof the data source, to be used for query planning.
- bindings- a-priori bindings supplied for the query, which can potentially be inlined.
- Returns:
- the optimized TupleExpr.
- Since:
- 3.0
- See Also:
- setOptimizerPipeline(QueryOptimizerPipeline)
 
 - 
evaluateCloseableIteration<BindingSet,QueryEvaluationException> evaluate(Service expr, String serviceUri, CloseableIteration<BindingSet,QueryEvaluationException> bindings) throws QueryEvaluationException Evaluates the tuple expression against the supplied triple source with the specified set of variable bindings as input.- Parameters:
- expr- The Service Expression to evaluate
- serviceUri- TODO
- bindings- The variables bindings iterator to use for evaluating the expression, if applicable.
- Returns:
- A closeable iterator over all of variable binding sets that match the tuple expression.
- Throws:
- QueryEvaluationException
 
 - 
evaluateCloseableIteration<BindingSet,QueryEvaluationException> evaluate(TupleExpr expr, BindingSet bindings) throws QueryEvaluationException Evaluates the tuple expression against the supplied triple source with the specified set of variable bindings as input.- Parameters:
- expr- The Tuple Expression to evaluate
- bindings- The variables bindings to use for evaluating the expression, if applicable.
- Returns:
- A closeable iterator over the variable binding sets that match the tuple expression.
- Throws:
- QueryEvaluationException
 
 - 
precompiledefault QueryEvaluationStep precompile(TupleExpr expr) Prepare a QueryEvaluationStep that tries to do as much work once per query avoiding repeated calls to the same code as much as possible. This depends on java invoke dynamic for performance.- Parameters:
- expr- that is to be evaluated later
- Returns:
- a QueryEvaluationStep that may avoid doing repeating the same work over and over.
 
 - 
precompiledefault QueryEvaluationStep precompile(TupleExpr expr, QueryEvaluationContext context) 
 - 
evaluateValue evaluate(ValueExpr expr, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException Gets the value of this expression.- Parameters:
- expr-
- bindings- The variables bindings to use for evaluating the expression, if applicable.
- Returns:
- The Value that this expression evaluates to, or null if the expression could not be evaluated.
- Throws:
- ValueExprEvaluationException
- QueryEvaluationException
 
 - 
isTrueboolean isTrue(ValueExpr expr, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException Evaluates the boolean expression on the supplied TripleSource object.- Parameters:
- expr-
- bindings- The variables bindings to use for evaluating the expression, if applicable.
- Returns:
- The result of the evaluation.
- Throws:
- ValueExprEvaluationException- If the value expression could not be evaluated, for example when comparing two incompatible operands. When thrown, the result of the boolean expression is neither true nor false , but unknown.
- QueryEvaluationException
 
 - 
isTrueboolean isTrue(QueryValueEvaluationStep expr, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException 
 - 
setTrackResultSize@Experimental default void setTrackResultSize(boolean trackResultSize) Enable or disable results size tracking for the query plan. Useful to determine which parts of a query plan generated the most data.- Parameters:
- trackResultSize- true to enable tracking.
 
 - 
isTrackResultSize@Experimental default boolean isTrackResultSize() Enable or disable results size tracking for the query plan.
 - 
setTrackTime@Experimental default void setTrackTime(boolean trackTime) Enable or disable time tracking for the query plan. Useful to determine which parts of a query plan take the most time to evaluate.- Parameters:
- trackTime- true to enable tracking.
 
 - 
getQueryEvaluationModeQueryEvaluationMode getQueryEvaluationMode() 
 - 
setQueryEvaluationModevoid setQueryEvaluationMode(QueryEvaluationMode queryEvaluationMode) 
 - 
precompiledefault QueryValueEvaluationStep precompile(ValueExpr arg, QueryEvaluationContext context) 
 - 
makeSetdefault <T> Set<T> makeSet() 
 - 
makeQueuedefault <T> Queue<T> makeQueue() 
 
- 
 
-