Class FederationEvalStrategy
- java.lang.Object
- 
- org.eclipse.rdf4j.query.algebra.evaluation.impl.StrictEvaluationStrategy
- 
- org.eclipse.rdf4j.federated.evaluation.FederationEvalStrategy
 
 
- 
- All Implemented Interfaces:
- EvaluationStrategy,- FederatedServiceResolver,- FederatedServiceResolverClient,- UUIDable
 - Direct Known Subclasses:
- SailFederationEvalStrategy,- SparqlFederationEvalStrategy
 
 public abstract class FederationEvalStrategy extends StrictEvaluationStrategy Base class for the Evaluation strategies.- Author:
- Andreas Schwarte
- See Also:
- SailFederationEvalStrategy,- SparqlFederationEvalStrategy
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected SourceSelectionCachecacheprotected Executorexecutorprotected FederationContextfederationContext- 
Fields inherited from class org.eclipse.rdf4j.query.algebra.evaluation.impl.StrictEvaluationStrategydataset, serviceResolver, tripleSource
 
- 
 - 
Constructor SummaryConstructors Constructor Description FederationEvalStrategy(FederationContext federationContext)
 - 
Method Summary- 
Methods inherited from class org.eclipse.rdf4j.query.algebra.evaluation.impl.StrictEvaluationStrategyevaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, evaluate, getLimit, getService, getUUID, getVarValue, isReducedOrDistinct, isTrue, isTrue, precompile, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, setFederatedServiceResolver, setOptimizerPipeline, setTrackResultSize, setTrackTime, supplyBinaryValueEvaluation, supplyUnaryValueEvaluation
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.query.algebra.evaluation.EvaluationStrategymakeQueue, makeSet
 
- 
 
- 
- 
- 
Field Detail- 
executorprotected Executor executor 
 - 
cacheprotected SourceSelectionCache cache 
 - 
federationContextprotected FederationContext federationContext 
 
- 
 - 
Constructor Detail- 
FederationEvalStrategypublic FederationEvalStrategy(FederationContext federationContext) 
 
- 
 - 
Method Detail- 
optimizepublic TupleExpr optimize(TupleExpr expr, EvaluationStatistics evaluationStatistics, BindingSet bindings) Description copied from class:StrictEvaluationStrategyExecute theQueryOptimizerPipelineon the givenTupleExprto optimize its execution plan.- Specified by:
- optimizein interface- EvaluationStrategy
- Overrides:
- optimizein class- StrictEvaluationStrategy
- Parameters:
- expr- the- TupleExprto optimize.
- evaluationStatistics- this param is ignored!
- bindings- a-priori bindings supplied for the query, which can potentially be inlined.
- Returns:
- the optimized TupleExpr.
- See Also:
- StrictEvaluationStrategy.setOptimizerPipeline(QueryOptimizerPipeline)
 
 - 
performSourceSelectionprotected Set<Endpoint> performSourceSelection(List<Endpoint> members, SourceSelectionCache cache, QueryInfo queryInfo, GenericInfoOptimizer info) Perform source selection for all statements of the query. As a result of this method all statement nodes are annotated with their relevant sources.- Parameters:
- members-
- cache-
- queryInfo-
- info-
- Returns:
- the set of relevant endpoints for the entire query
 
 - 
optimizeJoinOrderprotected void optimizeJoinOrder(TupleExpr query, QueryInfo queryInfo, GenericInfoOptimizer info) 
 - 
propagateServicesprotected boolean propagateServices(List<Service> serviceNodes) Whether to propagate aSingleSourceQuerycontaining SERVICE clauses. By default, the query is always evaluated within the FedX engine if it contains a SERVICE clause.Customized implementation may propagate a SingleSourceQueryincluding the SERVICE clause (e.g. for Wikidata the Label service can only be accessed in the wikidata endpoint.- Parameters:
- serviceNodes-
- Returns:
- if true, aSingleSourceQuerycontaining SERVICE clauses is propagated as-is
 
 - 
optimizeExclusiveExpressionsprotected void optimizeExclusiveExpressions(TupleExpr query, QueryInfo queryInfo, GenericInfoOptimizer info) OptimizeExclusiveTupleExpr, e.g. restructure the exclusive parts of the query AST.- Parameters:
- query-
- queryInfo-
- info-
 
 - 
evaluatepublic CloseableIteration<BindingSet,QueryEvaluationException> evaluate(TupleExpr expr, BindingSet bindings) throws QueryEvaluationException Description copied from interface:EvaluationStrategyEvaluates the tuple expression against the supplied triple source with the specified set of variable bindings as input.- Specified by:
- evaluatein interface- EvaluationStrategy
- Overrides:
- evaluatein class- StrictEvaluationStrategy
- 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
 
 - 
precompilepublic QueryEvaluationStep precompile(TupleExpr expr, QueryEvaluationContext context) throws QueryEvaluationException - Specified by:
- precompilein interface- EvaluationStrategy
- Overrides:
- precompilein class- StrictEvaluationStrategy
- Throws:
- QueryEvaluationException
 
 - 
getStatementspublic CloseableIteration<Statement,QueryEvaluationException> getStatements(QueryInfo queryInfo, Resource subj, IRI pred, Value obj, Resource... contexts) throws RepositoryException, MalformedQueryException, QueryEvaluationException Retrieve the statements matching the provided subject, predicate and object value from the federation members.For a bound statement, i.e. a statement with no free variables, the statement itself is returned if some member has this statement, an empty iteration otherwise. If the statement has free variables, i.e. one of the provided arguments in null, the union of results from relevant statement sources is constructed.- Parameters:
- subj-
- pred-
- obj-
- contexts-
- Returns:
- the statement iteration
- Throws:
- RepositoryException
- MalformedQueryException
- QueryEvaluationException
 
 - 
evaluateServicepublic CloseableIteration<BindingSet,QueryEvaluationException> evaluateService(FedXService service, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateSingleSourceQuerypublic CloseableIteration<BindingSet,QueryEvaluationException> evaluateSingleSourceQuery(SingleSourceQuery query, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateNJoinpublic CloseableIteration<BindingSet,QueryEvaluationException> evaluateNJoin(NJoin join, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
prepareNJoinprotected QueryEvaluationStep prepareNJoin(NJoin join, QueryEvaluationContext context) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateLeftJoinprotected CloseableIteration<BindingSet,QueryEvaluationException> evaluateLeftJoin(FedXLeftJoin leftJoin, BindingSet bindings) throws QueryEvaluationException Evaluate aFedXLeftJoin(i.e. an OPTIONAL clause)- Parameters:
- leftJoin-
- bindings-
- Returns:
- the resulting iteration
- Throws:
- QueryEvaluationException
- See Also:
- StrictEvaluationStrategy.evaluate(org.eclipse.rdf4j.query.algebra.LeftJoin, BindingSet)
 
 - 
prepareLeftJoinprotected QueryEvaluationStep prepareLeftJoin(FedXLeftJoin leftJoin, QueryEvaluationContext context) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateNaryUnionpublic CloseableIteration<BindingSet,QueryEvaluationException> evaluateNaryUnion(NUnion union, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
prepareNaryUnionpublic QueryEvaluationStep prepareNaryUnion(NUnion union, QueryEvaluationContext context) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
executeJoinprotected abstract CloseableIteration<BindingSet,QueryEvaluationException> executeJoin(ControlledWorkerScheduler<BindingSet> joinScheduler, CloseableIteration<BindingSet,QueryEvaluationException> leftIter, TupleExpr rightArg, Set<String> joinVariables, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException Execute the join in a separate thread using some join executor. Join executors are for instance: -SynchronousJoin-SynchronousBoundJoin-ControlledWorkerJoin-ControlledWorkerBoundJoinFor endpoint federation use controlled worker bound join, for local federation use controlled worker join. The other operators are there for completeness. Useexecutorto execute the join (it is a runnable).- Parameters:
- joinScheduler-
- leftIter-
- rightArg-
- joinVariables-
- bindings-
- Returns:
- the result
- Throws:
- QueryEvaluationException
 
 - 
evaluateExclusiveGrouppublic abstract CloseableIteration<BindingSet,QueryEvaluationException> evaluateExclusiveGroup(ExclusiveGroup group, BindingSet bindings) throws RepositoryException, MalformedQueryException, QueryEvaluationException 
 - 
evaluateExclusiveTupleExprprotected CloseableIteration<BindingSet,QueryEvaluationException> evaluateExclusiveTupleExpr(ExclusiveTupleExpr expr, BindingSet bindings) throws RepositoryException, MalformedQueryException, QueryEvaluationException Evaluate anExclusiveTupleExpr. The default implementation converts the given expression to a SELECT query string and evaluates it at the source.- Parameters:
- expr-
- bindings-
- Returns:
- the result
- Throws:
- RepositoryException
- MalformedQueryException
- QueryEvaluationException
 
 - 
prepareExclusiveTupleExprprotected QueryEvaluationStep prepareExclusiveTupleExpr(ExclusiveTupleExpr expr, QueryEvaluationContext context) throws RepositoryException, MalformedQueryException, QueryEvaluationException 
 - 
evaluateBoundJoinStatementPatternpublic abstract CloseableIteration<BindingSet,QueryEvaluationException> evaluateBoundJoinStatementPattern(StatementTupleExpr stmt, List<BindingSet> bindings) throws QueryEvaluationException Evaluate a bound join at the relevant endpoint, i.e. i.e. for a group of bindings retrieve results for the bound statement from the relevant endpoints- Parameters:
- stmt-
- bindings-
- Returns:
- the result iteration
- Throws:
- QueryEvaluationException
 
 - 
evaluateGroupedCheckpublic abstract CloseableIteration<BindingSet,QueryEvaluationException> evaluateGroupedCheck(CheckStatementPattern stmt, List<BindingSet> bindings) throws QueryEvaluationException Perform a grouped check at the relevant endpoints, i.e. for a group of bindings keep only those for which at least one endpoint provides a result to the bound statement.- Parameters:
- stmt-
- bindings-
- Returns:
- the result iteration
- Throws:
- QueryEvaluationException
 
 - 
evaluateServicepublic CloseableIteration<BindingSet,QueryEvaluationException> evaluateService(FedXService service, List<BindingSet> bindings) throws QueryEvaluationException Evaluate a SERVICE using vectored evaluation, taking the provided bindings as input. SeeControlledWorkerBoundJoinandFedXConfig.getEnableServiceAsBoundJoin()- Parameters:
- service-
- bindings-
- Returns:
- the result iteration
- Throws:
- QueryEvaluationException
 
 - 
evaluatepublic Value evaluate(ValueExpr expr, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException Description copied from interface:EvaluationStrategyGets the value of this expression.- Specified by:
- evaluatein interface- EvaluationStrategy
- Overrides:
- evaluatein class- StrictEvaluationStrategy
- 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
 
 - 
precompilepublic QueryValueEvaluationStep precompile(ValueExpr expr, QueryEvaluationContext context) throws ValueExprEvaluationException, QueryEvaluationException - Specified by:
- precompilein interface- EvaluationStrategy
- Overrides:
- precompilein class- StrictEvaluationStrategy
- Throws:
- ValueExprEvaluationException
- QueryEvaluationException
 
 - 
evaluatepublic Value evaluate(FilterExpr node, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException 
 - 
prepareprotected QueryValueEvaluationStep prepare(FilterExpr node, QueryEvaluationContext context) throws ValueExprEvaluationException, QueryEvaluationException 
 - 
evaluatepublic Value evaluate(ConjunctiveFilterExpr node, BindingSet bindings) throws ValueExprEvaluationException, QueryEvaluationException 
 - 
prepareprotected QueryValueEvaluationStep prepare(ConjunctiveFilterExpr node, QueryEvaluationContext context) throws ValueExprEvaluationException, QueryEvaluationException 
 - 
evaluatepublic CloseableIteration<BindingSet,QueryEvaluationException> evaluate(DescribeOperator operator, BindingSet bindings) throws QueryEvaluationException - Overrides:
- evaluatein class- StrictEvaluationStrategy
- Throws:
- QueryEvaluationException
 
 - 
evaluateAtStatementSourcesprotected CloseableIteration<BindingSet,QueryEvaluationException> evaluateAtStatementSources(Object preparedQuery, List<StatementSource> statementSources, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateAtStatementSourcesprotected CloseableIteration<BindingSet,QueryEvaluationException> evaluateAtStatementSources(String preparedQuery, List<StatementSource> statementSources, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
evaluateAtStatementSourcesprotected CloseableIteration<BindingSet,QueryEvaluationException> evaluateAtStatementSources(TupleExpr preparedQuery, List<StatementSource> statementSources, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 
-