mirror of https://github.com/apache/lucene.git
Avoid performance regression by constructing lazily the PointTree in NumericComparator (#13498) (#13877)
This commit is contained in:
parent
e37eaea11a
commit
07955ff88d
|
@ -333,6 +333,8 @@ Bug Fixes
|
|||
* GITHUB#12878: Fix the declared Exceptions of Expression#evaluate() to match those
|
||||
of DoubleValues#doubleValue(). (Uwe Schindler)
|
||||
|
||||
* GITHUB#13498: Avoid performance regression by constructing lazily the PointTree in NumericComparator, (Ignacio Vera)
|
||||
|
||||
Changes in Runtime Behavior
|
||||
---------------------
|
||||
|
||||
|
|
|
@ -95,7 +95,8 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
|
|||
private final LeafReaderContext context;
|
||||
protected final NumericDocValues docValues;
|
||||
private final PointValues pointValues;
|
||||
private final PointValues.PointTree pointTree;
|
||||
// lazily constructed to avoid performance overhead when this is not used
|
||||
private PointValues.PointTree pointTree;
|
||||
// if skipping functionality should be enabled on this segment
|
||||
private final boolean enableSkipping;
|
||||
private final int maxDoc;
|
||||
|
@ -139,7 +140,6 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
|
|||
+ " expected "
|
||||
+ bytesCount);
|
||||
}
|
||||
this.pointTree = pointValues.getPointTree();
|
||||
this.enableSkipping = true; // skipping is enabled when points are available
|
||||
this.maxDoc = context.reader().maxDoc();
|
||||
this.competitiveIterator = DocIdSetIterator.all(maxDoc);
|
||||
|
@ -147,7 +147,6 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
|
|||
encodeTop();
|
||||
}
|
||||
} else {
|
||||
this.pointTree = null;
|
||||
this.enableSkipping = false;
|
||||
this.maxDoc = 0;
|
||||
}
|
||||
|
@ -273,7 +272,8 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
|
|||
|
||||
final long threshold = iteratorCost >>> 3;
|
||||
|
||||
if (PointValues.isEstimatedPointCountGreaterThanOrEqualTo(visitor, pointTree, threshold)) {
|
||||
if (PointValues.isEstimatedPointCountGreaterThanOrEqualTo(
|
||||
visitor, getPointTree(), threshold)) {
|
||||
// the new range is not selective enough to be worth materializing, it doesn't reduce number
|
||||
// of docs at least 8x
|
||||
updateSkipInterval(false);
|
||||
|
@ -290,6 +290,13 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
|
|||
updateSkipInterval(true);
|
||||
}
|
||||
|
||||
private PointValues.PointTree getPointTree() throws IOException {
|
||||
if (pointTree == null) {
|
||||
pointTree = pointValues.getPointTree();
|
||||
}
|
||||
return pointTree;
|
||||
}
|
||||
|
||||
private void updateSkipInterval(boolean success) {
|
||||
if (updateCounter > 256) {
|
||||
if (success) {
|
||||
|
|
Loading…
Reference in New Issue