mirror of https://github.com/apache/lucene.git
LUCENE-8996: maxScore was sometimes missing from distributed grouped responses.
(Julien Massenet, Diego Ceccarelli, Christine Poerschke) Resolved Conflicts: lucene/grouping/src/java/org/apache/lucene/search/grouping/TopGroups.java
This commit is contained in:
parent
516f607618
commit
fb37f89af2
|
@ -170,6 +170,9 @@ Bug Fixes
|
|||
subclauses, and then pull SHOULD, MUST_NOT and FILTER visitors from it rather than from
|
||||
the parent. (Alan Woodward)
|
||||
|
||||
* LUCENE-8996: maxScore was sometimes missing from distributed grouped responses.
|
||||
(Julien Massenet, Diego Ceccarelli, Christine Poerschke)
|
||||
|
||||
Other
|
||||
|
||||
* LUCENE-8778 LUCENE-8911 LUCENE-8957: Define analyzer SPI names as static final fields and document the names in Javadocs.
|
||||
|
|
|
@ -80,6 +80,19 @@ public class TopGroups<T> {
|
|||
Avg,
|
||||
}
|
||||
|
||||
/**
|
||||
* If either value is NaN then return the other value, otherwise
|
||||
* return the greater of the two values by calling Math.max.
|
||||
* @param a - one value
|
||||
* @param b - another value
|
||||
* @return ignoring any NaN return the greater of a and b
|
||||
*/
|
||||
private static float nonNANmax(float a, float b) {
|
||||
if (Float.isNaN(a)) return b;
|
||||
if (Float.isNaN(b)) return a;
|
||||
return Math.max(a, b);
|
||||
}
|
||||
|
||||
/** Merges an array of TopGroups, for example obtained
|
||||
* from the second-pass collector across multiple
|
||||
* shards. Each TopGroups must have been sorted by the
|
||||
|
@ -169,7 +182,7 @@ public class TopGroups<T> {
|
|||
shardGroupDocs.scoreDocs,
|
||||
docSort.getSort());
|
||||
}
|
||||
maxScore = Math.max(maxScore, shardGroupDocs.maxScore);
|
||||
maxScore = nonNANmax(maxScore, shardGroupDocs.maxScore);
|
||||
assert shardGroupDocs.totalHits.relation == Relation.EQUAL_TO;
|
||||
totalHits += shardGroupDocs.totalHits.value;
|
||||
scoreSum += shardGroupDocs.score;
|
||||
|
@ -223,7 +236,7 @@ public class TopGroups<T> {
|
|||
mergedScoreDocs,
|
||||
groupValue,
|
||||
shardGroups[0].groups[groupIDX].groupSortValues);
|
||||
totalMaxScore = Math.max(totalMaxScore, maxScore);
|
||||
totalMaxScore = nonNANmax(totalMaxScore, maxScore);
|
||||
}
|
||||
|
||||
if (totalGroupCount != null) {
|
||||
|
|
|
@ -21,16 +21,12 @@ import org.apache.lucene.search.Sort;
|
|||
import org.apache.lucene.search.TotalHits;
|
||||
import org.apache.lucene.util.LuceneTestCase;
|
||||
|
||||
import org.junit.Ignore;
|
||||
|
||||
public class TopGroupsTest extends LuceneTestCase {
|
||||
|
||||
@Ignore // https://issues.apache.org/jira/browse/LUCENE-8996
|
||||
public void testAllGroupsEmptyInSecondPass() {
|
||||
narrativeMergeTestImplementation(false, false, false, false);
|
||||
}
|
||||
|
||||
@Ignore // https://issues.apache.org/jira/browse/LUCENE-8996
|
||||
public void testSomeGroupsEmptyInSecondPass() {
|
||||
narrativeMergeTestImplementation(false, false, false, true);
|
||||
narrativeMergeTestImplementation(false, false, true, false);
|
||||
|
|
Loading…
Reference in New Issue