Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement construct PrefilterExpression from SparqlExpression. #1573

Closed
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
99da434
Added conversion str to int
realHannes Apr 25, 2024
424d023
templated function for toNumeric, add declaration to NaryExpression.h
realHannes Apr 25, 2024
0117e82
str to num for SparqlExpression implemented + added test
realHannes Apr 25, 2024
35fd0b1
Merge branch 'ad-freiburg:master' into master
realHannes Apr 26, 2024
94356c2
Update src/engine/sparqlExpressions/StringExpressions.cpp
realHannes Apr 26, 2024
decc8ba
Update src/engine/sparqlExpressions/StringExpressions.cpp
realHannes Apr 26, 2024
850152c
Update src/engine/sparqlExpressions/StringExpressions.cpp
realHannes Apr 26, 2024
d650d67
Update src/engine/sparqlExpressions/StringExpressions.cpp
realHannes Apr 26, 2024
46cc697
using now absl::from_chars() and stripping whitespaces for string to …
realHannes Apr 26, 2024
7fc5c28
added new functions to processIriFuntionCall() (for string to number)
realHannes Apr 26, 2024
efb0e24
renaming to: toIntExpression and toDoubleExpression for later more ge…
realHannes Apr 26, 2024
a88537c
made format (clang-format-16)
realHannes Apr 26, 2024
ca1e2e0
Update src/parser/sparqlParser/SparqlQleverVisitor.cpp
realHannes Apr 29, 2024
4adc831
Update src/parser/sparqlParser/SparqlQleverVisitor.cpp
realHannes Apr 29, 2024
d0f0d63
renaming in NaryExpression.h for accordance with other function, addi…
realHannes Apr 29, 2024
a118609
added test coverage for function calls makeIntExpression and make Dou…
realHannes Apr 29, 2024
062052e
toNumeric has now correct behavior and uses absl::from_chars() and st…
realHannes Apr 29, 2024
6d0f42a
made clang-format for NaryExpressionImpl.h
realHannes Apr 29, 2024
f90b8e2
Merge branch 'ad-freiburg:master' into master
realHannes May 6, 2024
fb88493
Merge branch 'ad-freiburg:master' into master
realHannes May 15, 2024
b2eb514
Merge remote-tracking branch 'upstream/master'
realHannes May 16, 2024
b165ac1
Merge branch 'ad-freiburg:master' into master
realHannes Jun 1, 2024
7a3dfb2
Merge branch 'master' of https://github.com/realHannes/qlever
realHannes Jun 1, 2024
fc0ad3a
Merge branch 'ad-freiburg:master' into master
realHannes Jun 6, 2024
f3e6086
Merge branch 'ad-freiburg:master' into master
realHannes Jun 7, 2024
fd4c351
Merge branch 'ad-freiburg:master' into master
realHannes Jun 10, 2024
220c9bf
Merge branch 'ad-freiburg:master' into master
realHannes Jun 12, 2024
a81cb8a
Merge branch 'ad-freiburg:master' into master
realHannes Jun 13, 2024
acc0109
Merge branch 'ad-freiburg:master' into master
realHannes Jun 14, 2024
cb8e560
Merge branch 'ad-freiburg:master' into master
realHannes Jun 20, 2024
2b39970
Merge branch 'ad-freiburg:master' into master
realHannes Jun 28, 2024
a0101e4
Merge branch 'ad-freiburg:master' into master
realHannes Jun 30, 2024
47dee1d
Merge branch 'ad-freiburg:master' into master
realHannes Sep 4, 2024
a8625f9
Merge branch 'ad-freiburg:master' into master
realHannes Sep 9, 2024
7f95069
Merge branch 'ad-freiburg:master' into master
realHannes Sep 12, 2024
28b8a69
Merge branch 'ad-freiburg:master' into master
realHannes Sep 13, 2024
7bb6e01
Merge branch 'ad-freiburg:master' into master
realHannes Sep 14, 2024
edc974a
Add implementation for pre-filtering blocks on their metadata
realHannes Sep 18, 2024
ca6c2ff
Merge branch 'master' into prefilter_on_metadata_relational
realHannes Sep 18, 2024
46be51a
fix spelling error
realHannes Sep 18, 2024
0385b56
add namespace for CompressedBlockPrefiltering.h
realHannes Sep 18, 2024
5707338
use std::ranges::set_union, std::ranges::upper_bound/lower_bound
realHannes Sep 18, 2024
c9687ec
move template specializations into namespace prefilterExpressions
realHannes Sep 18, 2024
d8246f7
fix
realHannes Sep 18, 2024
66b4872
hopefully fix namespace issue
realHannes Sep 18, 2024
e4eddc4
Merge branch 'ad-freiburg:master' into prefilter_on_metadata_relational
realHannes Sep 20, 2024
b5d7dd7
first adaptations regarding the comments
realHannes Sep 20, 2024
802e3aa
Merge branch 'ad-freiburg:master' into prefilter_on_metadata_relational
realHannes Sep 23, 2024
662b1d4
applied suggestions from review
realHannes Sep 24, 2024
510aa9e
fix std::move
realHannes Sep 24, 2024
0d7f75b
Merge branch 'ad-freiburg:master' into prefilter_on_metadata_relational
realHannes Sep 25, 2024
c119200
adjusted CompressedBlockPrefiltering
realHannes Sep 26, 2024
af17181
mark method with override
realHannes Sep 26, 2024
3d7238d
Merge branch 'master' into prefilter_on_metadata_relational
realHannes Oct 8, 2024
5af6138
make further changes to prefiltering procedure and its tests
realHannes Oct 8, 2024
b02dc57
add additional testing on IDs from other datatypes
realHannes Oct 8, 2024
eb86f1b
addition to test Not Expression with And and Or
realHannes Oct 8, 2024
69ed019
changes to test and fix index check fail
realHannes Oct 9, 2024
854322b
increase test coverage for Not expression
realHannes Oct 9, 2024
b2aa689
just add all mixed blocks
realHannes Oct 9, 2024
546c3b3
Merge branch 'ad-freiburg:master' into prefilter_on_metadata_relational
realHannes Oct 9, 2024
7e61cb1
remove unnecessary values in test context
realHannes Oct 9, 2024
009ebed
for sonar check
realHannes Oct 10, 2024
6c19bf6
Merge branch 'ad-freiburg:master' into prefilter_on_metadata_relational
realHannes Oct 10, 2024
bf733ce
Merge branch 'ad-freiburg:master' into environment_for_using_prefilte…
realHannes Oct 12, 2024
5b42c1f
methods to get PrefilterExpresssions from RelationalExpressions (Spar…
realHannes Oct 12, 2024
6cf6609
Completed the implementation for constructing PrefilterExpressions fr…
realHannes Oct 22, 2024
18c4c84
Merge branch 'master' into environment_for_using_prefiltering
realHannes Oct 22, 2024
e4be1fe
all builds should compile now
realHannes Oct 22, 2024
bde09cd
Merge branch 'ad-freiburg:master' into environment_for_using_prefilte…
realHannes Oct 22, 2024
74756fe
fix build issue and increase test coverage
realHannes Oct 22, 2024
1278d39
Merge branch 'master' into environment_for_using_prefiltering
realHannes Oct 22, 2024
47d3d56
Merge branch 'ad-freiburg:master' into environment_for_using_prefilte…
realHannes Oct 25, 2024
49de4d0
introduce test structure from PR1 (#1503)
realHannes Oct 25, 2024
fcefdf0
Merge branch 'master' into environment_for_using_prefiltering
realHannes Oct 28, 2024
9f0efc6
fix build
realHannes Oct 28, 2024
25f325a
implement proposed changes (2)
realHannes Oct 30, 2024
d65acc3
correction for codespell check
realHannes Oct 30, 2024
f85a96f
fix for codespell
realHannes Oct 30, 2024
0a188a5
Merge branch 'ad-freiburg:master' into environment_for_using_prefilte…
realHannes Oct 31, 2024
5f4e586
remove optionality (std::optional) for return value
realHannes Oct 31, 2024
8062753
Merge branch 'ad-freiburg:master' into environment_for_using_prefilte…
realHannes Nov 4, 2024
c06de60
implement proposed improvements (4)
realHannes Nov 4, 2024
95e9027
further adjustments + apply PrefilterExpressions in IndexScan
realHannes Nov 11, 2024
0992fab
Merge branch 'master' into environment_for_using_prefiltering
realHannes Nov 11, 2024
f489b24
few additional adaptations
realHannes Nov 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 15 additions & 1 deletion src/engine/Filter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,9 @@ Filter::Filter(QueryExecutionContext* qec,
sparqlExpression::SparqlExpressionPimpl expression)
: Operation(qec),
_subtree(std::move(subtree)),
_expression{std::move(expression)} {}
_expression{std::move(expression)} {
setPrefilterExpressionForIndexScanChildren();
}

// _____________________________________________________________________________
string Filter::getCacheKeyImpl() const {
Expand All @@ -37,10 +39,22 @@ string Filter::getCacheKeyImpl() const {
return std::move(os).str();
}

//______________________________________________________________________________
string Filter::getDescriptor() const {
return absl::StrCat("Filter ", _expression.getDescriptor());
}

//______________________________________________________________________________
void Filter::setPrefilterExpressionForIndexScanChildren() {
const std::vector<PrefilterVariablePair>& prefilterVec =
_expression.getPrefilterExpressionForMetadata();
this->forAllDescendants([&prefilterVec](const QueryExecutionTree* ptr) {
if (ptr) {
ptr->setPrefilterExpression(prefilterVec);
}
});
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some detailed comments here:

  1. You may only pass on PrefilterExpressions to a child execution tree, if the variable of the expression is visible in the variable to column map. Otherwise you have the case that subqueries filter out too much.

  2. It is fishy (and leads to unexpected behavior) if you just change the Operation without informing the shared_ptr<ExecutionTree> that owns it.
    So what you need, is a forThisExecutionTreeAndAllDescendents(shared_ptr) that completely replaces the shared_ptr with a completely new execution tree (via make_sharedor respectivelyad_utility::createExecutionTree) that stores the IndexScan. Then you best have a function in the IndexScanClass that can do something like shared_ptr makeCopyWithAddedPrefilters(Prefilters) const(we have something similar in theTransitivePathclass called bindLeftOrRightSide`.

  3. You should make two PRs out of this, one for the extraction of the prefilters out of the expression (the first part of this PR), and then this second one here which is based on that one. Because then we can merge the first part earlier (which is further in the review process), and it gets much easier to review.

}

// _____________________________________________________________________________
ProtoResult Filter::computeResult(bool requestLaziness) {
LOG(DEBUG) << "Getting sub-result for Filter result computation..." << endl;
Expand Down
5 changes: 4 additions & 1 deletion src/engine/Filter.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,11 @@

#include "engine/Operation.h"
#include "engine/QueryExecutionTree.h"
#include "engine/sparqlExpressions/SparqlExpressionPimpl.h"
#include "parser/ParsedQuery.h"

class Filter : public Operation {
using PrefilterVariablePair = sparqlExpression::PrefilterExprVariablePair;

private:
std::shared_ptr<QueryExecutionTree> _subtree;
sparqlExpression::SparqlExpressionPimpl _expression;
Expand Down Expand Up @@ -58,6 +59,8 @@ class Filter : public Operation {
return _subtree->getVariableColumns();
}

void setPrefilterExpressionForIndexScanChildren();
realHannes marked this conversation as resolved.
Show resolved Hide resolved

ProtoResult computeResult(bool requestLaziness) override;

// Perform the actual filter operation of the data provided.
Expand Down
111 changes: 78 additions & 33 deletions src/engine/IndexScan.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,15 @@

// _____________________________________________________________________________
IndexScan::IndexScan(QueryExecutionContext* qec, Permutation::Enum permutation,
const SparqlTripleSimple& triple, Graphs graphsToFilter)
const SparqlTripleSimple& triple, Graphs graphsToFilter,
PrefilterIndexPairs prefilters)
: Operation(qec),
permutation_(permutation),
subject_(triple.s_),
predicate_(triple.p_),
object_(triple.o_),
graphsToFilter_{std::move(graphsToFilter)},
prefilters_{std::move(prefilters)},
numVariables_(static_cast<size_t>(subject_.isVariable()) +
static_cast<size_t>(predicate_.isVariable()) +
static_cast<size_t>(object_.isVariable())) {
Expand Down Expand Up @@ -51,9 +53,10 @@

// _____________________________________________________________________________
IndexScan::IndexScan(QueryExecutionContext* qec, Permutation::Enum permutation,
const SparqlTriple& triple, Graphs graphsToFilter)
: IndexScan(qec, permutation, triple.getSimple(),
std::move(graphsToFilter)) {}
const SparqlTriple& triple, Graphs graphsToFilter,
PrefilterIndexPairs prefilters)
: IndexScan(qec, permutation, triple.getSimple(), std::move(graphsToFilter),
std::move(prefilters)) {}

// _____________________________________________________________________________
string IndexScan::getCacheKeyImpl() const {
Expand Down Expand Up @@ -115,6 +118,24 @@
return result;
}

// _____________________________________________________________________________
void IndexScan::setPrefilterExpression(
const std::vector<PrefilterVariablePair>& prefilterVariablePairs) {
const std::vector<ColumnIndex>& sortedColumns = resultSortedOn();
VariableToColumnMap varToColMap = computeVariableToColumnMap();

const auto addPrefilterIfSorted = [&](const PrefilterVariablePair& pair) {
const Variable& variable = pair.second;

Check warning on line 128 in src/engine/IndexScan.cpp

View check run for this annotation

Codecov / codecov/patch

src/engine/IndexScan.cpp#L128

Added line #L128 was not covered by tests
if (varToColMap.find(variable) != varToColMap.end()) {
const ColumnIndex colIdx = varToColMap[variable].columnIndex_;

Check warning on line 130 in src/engine/IndexScan.cpp

View check run for this annotation

Codecov / codecov/patch

src/engine/IndexScan.cpp#L130

Added line #L130 was not covered by tests
if (std::ranges::find(sortedColumns, colIdx) != sortedColumns.end()) {
realHannes marked this conversation as resolved.
Show resolved Hide resolved
prefilters_.push_back(std::make_pair(pair.first->clone(), colIdx));
}
}
};

Check warning on line 135 in src/engine/IndexScan.cpp

View check run for this annotation

Codecov / codecov/patch

src/engine/IndexScan.cpp#L132-L135

Added lines #L132 - L135 were not covered by tests
std::ranges::for_each(prefilterVariablePairs, addPrefilterIfSorted);
}

// _____________________________________________________________________________
VariableToColumnMap IndexScan::computeVariableToColumnMap() const {
VariableToColumnMap variableToColumnMap;
Expand All @@ -134,40 +155,63 @@
return variableToColumnMap;
}

//______________________________________________________________________________
std::vector<CompressedBlockMetadata> IndexScan::applyFilterBlockMetadata(
std::vector<CompressedBlockMetadata>&& blocks) const {
std::ranges::for_each(prefilters_, [&blocks](const PrefilterIndexPair& pair) {
pair.first->evaluate(blocks, pair.second);
realHannes marked this conversation as resolved.
Show resolved Hide resolved
});

Check warning on line 163 in src/engine/IndexScan.cpp

View check run for this annotation

Codecov / codecov/patch

src/engine/IndexScan.cpp#L162-L163

Added lines #L162 - L163 were not covered by tests
return blocks;
};

// _____________________________________________________________________________
Result::Generator IndexScan::scanInChunks() const {
Result::Generator IndexScan::chunkedIndexScan() const {
auto metadata = getMetadataForScan();
if (!metadata.has_value()) {
co_return;
}
auto blocksSpan =
CompressedRelationReader::getBlocksFromMetadata(metadata.value());
std::vector<CompressedBlockMetadata> blocks{blocksSpan.begin(),
blocksSpan.end()};
for (IdTable& idTable : getLazyScan(std::move(blocks))) {
for (IdTable& idTable : getLazyScan({blocksSpan.begin(), blocksSpan.end()})) {
co_yield {std::move(idTable), LocalVocab{}};
}
}

// _____________________________________________________________________________
ProtoResult IndexScan::computeResult(bool requestLaziness) {
LOG(DEBUG) << "IndexScan result computation...\n";
if (requestLaziness) {
return {scanInChunks(), resultSortedOn()};
}
IdTable idTable{getExecutionContext()->getAllocator()};

IdTable IndexScan::completeIndexScan() const {
realHannes marked this conversation as resolved.
Show resolved Hide resolved
// Get the blocks.
auto metadata = getMetadataForScan();
auto blockSpan =
metadata.has_value()
? CompressedRelationReader::getBlocksFromMetadata(metadata.value())
: std::span<const CompressedBlockMetadata>{};
auto optFilteredBlocks = getLimit().isUnconstrained()
? std::optional{applyFilterBlockMetadata(
{blockSpan.begin(), blockSpan.end()})}
: std::nullopt;
// Create IdTable, fill it with content by performing scan().
using enum Permutation::Enum;
IdTable idTable{getExecutionContext()->getAllocator()};
idTable.setNumColumns(numVariables_);
const auto& index = _executionContext->getIndex();
idTable =
index.scan(getScanSpecification(), permutation_, additionalColumns(),
cancellationHandle_, locatedTriplesSnapshot(), getLimit());
idTable = index.getImpl()
.getPermutation(permutation_)
.scan(getScanSpecification(), additionalColumns(),
cancellationHandle_, locatedTriplesSnapshot(), getLimit(),
optFilteredBlocks);
AD_CORRECTNESS_CHECK(idTable.numColumns() == getResultWidth());
LOG(DEBUG) << "IndexScan result computation done.\n";
checkCancellation();
return idTable;
}

return {std::move(idTable), resultSortedOn(), LocalVocab{}};
// _____________________________________________________________________________
ProtoResult IndexScan::computeResult(bool requestLaziness) {
LOG(DEBUG) << "IndexScan result computation...\n";
if (requestLaziness) {
return {chunkedIndexScan(), resultSortedOn()};
}
return {completeIndexScan(), getResultSortedOn(), LocalVocab{}};
}

// _____________________________________________________________________________
Expand Down Expand Up @@ -208,7 +252,7 @@
AD_CONTRACT_CHECK(multiplicity_.size() == getResultWidth());
}

// ___________________________________________________________________________
// _____________________________________________________________________________
std::array<const TripleComponent* const, 3> IndexScan::getPermutedTriple()
const {
std::array triple{&subject_, &predicate_, &object_};
Expand All @@ -217,30 +261,30 @@
triple[permutation[2]]};
}

// ___________________________________________________________________________
// _____________________________________________________________________________
ScanSpecification IndexScan::getScanSpecification() const {
const IndexImpl& index = getIndex().getImpl();
return getScanSpecificationTc().toScanSpecification(index);
}

// ___________________________________________________________________________
// _____________________________________________________________________________
ScanSpecificationAsTripleComponent IndexScan::getScanSpecificationTc() const {
auto permutedTriple = getPermutedTriple();
return {*permutedTriple[0], *permutedTriple[1], *permutedTriple[2],
graphsToFilter_};
}

// ___________________________________________________________________________
// _____________________________________________________________________________
Permutation::IdTableGenerator IndexScan::getLazyScan(
std::vector<CompressedBlockMetadata> blocks) const {
std::vector<CompressedBlockMetadata>&& blocks) const {
// If there is a LIMIT or OFFSET clause that constrains the scan
// (which can happen with an explicit subquery), we cannot use the prefiltered
// blocks, as we currently have no mechanism to include limits and offsets
// into the prefiltering (`std::nullopt` means `scan all blocks`).
auto actualBlocks = getLimit().isUnconstrained()
? std::optional{std::move(blocks)}
: std::nullopt;

auto actualBlocks =
getLimit().isUnconstrained()
? std::optional{applyFilterBlockMetadata(std::move(blocks))}
: std::nullopt;
return getIndex()
.getImpl()
.getPermutation(permutation())
Expand All @@ -249,15 +293,15 @@
locatedTriplesSnapshot(), getLimit());
};

// ________________________________________________________________
// _____________________________________________________________________________
std::optional<Permutation::MetadataAndBlocks> IndexScan::getMetadataForScan()
const {
const auto& index = getExecutionContext()->getIndex().getImpl();
return index.getPermutation(permutation())
.getMetadataAndBlocks(getScanSpecification(), locatedTriplesSnapshot());
};

// ________________________________________________________________
// _____________________________________________________________________________
std::array<Permutation::IdTableGenerator, 2>
IndexScan::lazyScanForJoinOfTwoScans(const IndexScan& s1, const IndexScan& s2) {
AD_CONTRACT_CHECK(s1.numVariables_ <= 3 && s2.numVariables_ <= 3);
Expand Down Expand Up @@ -300,13 +344,14 @@
auto [blocks1, blocks2] = CompressedRelationReader::getBlocksForJoin(
metaBlocks1.value(), metaBlocks2.value());

std::array result{s1.getLazyScan(blocks1), s2.getLazyScan(blocks2)};
std::array result{s1.getLazyScan(std::move(blocks1)),
s2.getLazyScan(std::move(blocks2))};
result[0].details().numBlocksAll_ = metaBlocks1.value().blockMetadata_.size();
result[1].details().numBlocksAll_ = metaBlocks2.value().blockMetadata_.size();
return result;
}

// ________________________________________________________________
// _____________________________________________________________________________
Permutation::IdTableGenerator IndexScan::lazyScanForJoinOfColumnWithScan(
std::span<const Id> joinColumn) const {
AD_EXPENSIVE_CHECK(std::ranges::is_sorted(joinColumn));
Expand All @@ -321,7 +366,7 @@
auto blocks = CompressedRelationReader::getBlocksForJoin(joinColumn,
metaBlocks1.value());

auto result = getLazyScan(blocks);
auto result = getLazyScan(std::move(blocks));
result.details().numBlocksAll_ = metaBlocks1.value().blockMetadata_.size();
return result;
}
35 changes: 29 additions & 6 deletions src/engine/IndexScan.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,21 @@ class SparqlTriple;
class SparqlTripleSimple;

class IndexScan final : public Operation {
using Graphs = ScanSpecificationAsTripleComponent::Graphs;
// Pair containing a `PrefilterExpression` with `ColumnIndex` (eval. index)
using PrefilterIndexPair =
std::pair<std::unique_ptr<prefilterExpressions::PrefilterExpression>,
ColumnIndex>;
// Vector with `PrefilterIndexPair` values.
using PrefilterIndexPairs = std::vector<PrefilterIndexPair>;

private:
Permutation::Enum permutation_;
TripleComponent subject_;
TripleComponent predicate_;
TripleComponent object_;
using Graphs = ScanSpecificationAsTripleComponent::Graphs;
Graphs graphsToFilter_;
PrefilterIndexPairs prefilters_;
size_t numVariables_;
size_t sizeEstimate_;
vector<float> multiplicity_;
Expand All @@ -30,10 +38,12 @@ class IndexScan final : public Operation {

public:
IndexScan(QueryExecutionContext* qec, Permutation::Enum permutation,
const SparqlTriple& triple, Graphs graphsToFilter = std::nullopt);
const SparqlTriple& triple, Graphs graphsToFilter = std::nullopt,
PrefilterIndexPairs prefilters = {});
IndexScan(QueryExecutionContext* qec, Permutation::Enum permutation,
const SparqlTripleSimple& triple,
Graphs graphsToFilter = std::nullopt);
Graphs graphsToFilter = std::nullopt,
PrefilterIndexPairs prefilters = {});

~IndexScan() override = default;

Expand All @@ -55,6 +65,10 @@ class IndexScan final : public Operation {

vector<ColumnIndex> resultSortedOn() const override;

// Set `PrefilterExpression`s.
void setPrefilterExpression(const std::vector<PrefilterVariablePair>&
prefilterVariablePairs) override;

size_t numVariables() const { return numVariables_; }

// Return the exact result size of the index scan. This is always known as it
Expand Down Expand Up @@ -130,10 +144,19 @@ class IndexScan final : public Operation {

VariableToColumnMap computeVariableToColumnMap() const override;

Result::Generator scanInChunks() const;
// Filter relevant `CompressedBlockMetadata` blocks by applying the
// `PrefilterExpression`s from `prefilters_`.
std::vector<CompressedBlockMetadata> applyFilterBlockMetadata(
std::vector<CompressedBlockMetadata>&& blocks) const;

// Return the (lazy) `IdTable` for this `IndexScan` in chunks.
Result::Generator chunkedIndexScan() const;
// Get the `IdTable` for this `IndexScan` in one piece.
IdTable completeIndexScan() const;

// Helper functions for the public `getLazyScanFor...` functions (see above).
// Helper functions for the public `getLazyScanFor...` methods and
// `chunkedIndexScan` (see above).
Permutation::IdTableGenerator getLazyScan(
std::vector<CompressedBlockMetadata> blocks) const;
std::vector<CompressedBlockMetadata>&& blocks) const;
realHannes marked this conversation as resolved.
Show resolved Hide resolved
std::optional<Permutation::MetadataAndBlocks> getMetadataForScan() const;
};
Loading
Loading