Skip to content

Commit

Permalink
update
Browse files Browse the repository at this point in the history
Signed-off-by: bowenlan-amzn <[email protected]>
  • Loading branch information
bowenlan-amzn committed Jan 8, 2025
1 parent 8de4f5b commit 23684a7
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 96 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -42,22 +42,13 @@
import org.apache.lucene.document.LongPoint;
import org.apache.lucene.document.SortedNumericDocValuesField;
import org.apache.lucene.document.StoredField;
import org.apache.lucene.index.LeafReaderContext;
import org.apache.lucene.sandbox.document.BigIntegerPoint;
import org.apache.lucene.sandbox.document.HalfFloatPoint;
import org.apache.lucene.search.BoostQuery;
import org.apache.lucene.search.ConstantScoreWeight;
import org.apache.lucene.search.IndexOrDocValuesQuery;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.IndexSortSortedNumericDocValuesRangeQuery;
import org.apache.lucene.search.MatchNoDocsQuery;
import org.apache.lucene.search.PointInSetQuery;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.QueryVisitor;
import org.apache.lucene.search.ScoreMode;
import org.apache.lucene.search.Scorer;
import org.apache.lucene.search.ScorerSupplier;
import org.apache.lucene.search.Weight;
import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.NumericUtils;
import org.opensearch.common.Explicit;
Expand Down Expand Up @@ -89,7 +80,6 @@
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Objects;
Expand Down Expand Up @@ -1515,92 +1505,6 @@ public static Query unsignedLongRangeQuery(
}
return builder.apply(l, u);
}

static Query bitmapIndexQuery(String field, RoaringBitmap bitmap) {
return new Query() {

@Override
public String toString(String field) {
return "";
}

@Override
public void visit(QueryVisitor visitor) {

}

@Override
public boolean equals(Object obj) {
return false;
}

@Override
public int hashCode() {
return 0;
}

@Override
public Weight createWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) {
return new ConstantScoreWeight(this, boost) {
@Override
public Scorer scorer(LeafReaderContext context) throws IOException {
return scorerSupplier(context).get(Long.MAX_VALUE);
}

@Override
public ScorerSupplier scorerSupplier(LeafReaderContext context) throws IOException {
return new ScorerSupplier() {
@Override
public Scorer get(long leadCost) throws IOException {
final BytesRef encoded = new BytesRef(new byte[Integer.BYTES]);
Query query = new PointInSetQuery(field, 1, Integer.BYTES, new PointInSetQuery.Stream() {
final Iterator<Integer> iterator = bitmap.iterator();

@Override
public BytesRef next() {
int value;
if (iterator.hasNext()) {
value = iterator.next();
} else {
return null;
}
IntPoint.encodeDimension(value, encoded.bytes, 0);
return encoded;
}
}) {
@Override
public Query rewrite(IndexSearcher indexSearcher) throws IOException {
if (bitmap.isEmpty()) {
return new MatchNoDocsQuery();
}
return super.rewrite(indexSearcher);
}

@Override
protected String toString(byte[] value) {
assert value.length == Integer.BYTES;
return Integer.toString(IntPoint.decodeDimension(value, 0));
}
};

return query.createWeight(searcher, scoreMode, boost).scorer(context);
}

@Override
public long cost() {
return bitmap.getLongCardinality();
}
};
}

@Override
public boolean isCacheable(LeafReaderContext ctx) {
return false;
}
};
}
};
}
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@

import org.roaringbitmap.RoaringBitmap;

import static org.opensearch.search.query.BitmapIndexQuery.checkArgs;

/**
* Filter with bitmap
* <p>
Expand All @@ -43,6 +45,7 @@ public class BitmapDocValuesQuery extends Query implements Accountable {
final long max;

public BitmapDocValuesQuery(String field, RoaringBitmap bitmap) {
checkArgs(field, bitmap);
this.field = field;
this.bitmap = bitmap;
if (!bitmap.isEmpty()) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,10 +47,20 @@ public class BitmapIndexQuery extends Query implements Accountable {
private final String field;

public BitmapIndexQuery(String field, RoaringBitmap bitmap) {
checkArgs(field, bitmap);
this.bitmap = bitmap;
this.field = field;
}

static void checkArgs(String field, RoaringBitmap bitmap) {
if (field == null) {
throw new IllegalArgumentException("field must not be null");
}
if (bitmap == null) {
throw new IllegalArgumentException("bitmap must not be null");
}
}

interface BitmapIterator extends BytesRefIterator {
// wrap IntIterator.next()
BytesRef next();
Expand Down

0 comments on commit 23684a7

Please sign in to comment.