shubhamvishu commented on code in PR #12868:
URL: https://github.com/apache/lucene/pull/12868#discussion_r1414510733


##########
lucene/codecs/src/java/org/apache/lucene/codecs/bloom/FuzzySet.java:
##########
@@ -150,9 +150,10 @@ private FuzzySet(FixedBitSet filter, int bloomSize, int 
hashCount) {
    * @return NO or MAYBE
    */
   public ContainsResult contains(BytesRef value) {
-    long hash = hashFunction.hash(value);
-    int msb = (int) (hash >>> Integer.SIZE);
-    int lsb = (int) hash;
+    long[] hash = hashFunction.hash128(value);
+
+    int msb = ((int) hash[0] >>> Integer.SIZE) >>> 1 + ((int) hash[1] >>> 
Integer.SIZE) >>> 1;
+    int lsb = ((int) hash[0]) >>> 1 + ((int) hash[1]) >>> 1;

Review Comment:
   I can try to run benchmarks with that and see how that turns out.....but 
with the current logic (below) we see 7-9% better performance consistently(see 
above benchmark results). Could that be misleading by any chance because this 
is more probable to produce 0 value or maybe worth sticking to that since 
benchmarks say a different story?
   
   ```java
   int msb = ((int) hash[0] >>> Integer.SIZE) >>> 1 + ((int) hash[1] >>> 
Integer.SIZE) >>> 1;
   int lsb = ((int) hash[0]) >>> 1 + ((int) hash[1]) >>> 1;
   ```



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to