gianm edited a comment on pull request #10430:
URL: https://github.com/apache/druid/pull/10430#issuecomment-698026349


   Btw, the coverage here is decent from existing tests (most of the new lines 
are getting called), but I think it needs some more explicit coverage so I 
marked it as a draft. I'll add some.
   
   I did some benchmarks: in IndexedTableJoinCursorBenchmark with long keys, 
it's about a 2x speedup for the first four projection types. (I didn't test the 
others.)
   
   ```
   master
   
   Benchmark                                                         
(indexedTableType)    (joinColumns)  (projection)  (rowsPerSegment)  
(rowsPerTableSegment)  Mode  Cnt  Score   Error  Units
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             0             50000                5000000 
 avgt   10  2.483 ± 0.057  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             1             50000                5000000 
 avgt   10  2.440 ± 0.155  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             2             50000                5000000 
 avgt   10  2.975 ± 0.055  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             3             50000                5000000 
 avgt   10  3.910 ± 0.426  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             0             50000                5000000 
 avgt   10  3.570 ± 0.420  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             1             50000                5000000 
 avgt   10  3.354 ± 0.122  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             2             50000                5000000 
 avgt   10  3.737 ± 0.098  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             3             50000                5000000 
 avgt   10  4.534 ± 0.322  ms/op
   
   patch
   
   Benchmark                                                         
(indexedTableType)    (joinColumns)  (projection)  (rowsPerSegment)  
(rowsPerTableSegment)  Mode  Cnt  Score   Error  Units
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             0             50000                5000000 
 avgt   10  1.247 ± 0.033  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             1             50000                5000000 
 avgt   10  1.226 ± 0.067  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             2             50000                5000000 
 avgt   10  1.617 ± 0.088  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment    long3,longKey             3             50000                5000000 
 avgt   10  2.174 ± 0.024  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             0             50000                5000000 
 avgt   10  1.479 ± 0.070  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             1             50000                5000000 
 avgt   10  1.599 ± 0.145  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             2             50000                5000000 
 avgt   10  1.963 ± 0.105  ms/op
   IndexedTableJoinCursorBenchmark.hashJoinCursorDimensionSelectors             
segment  longKey,longKey             3             50000                5000000 
 avgt   10  2.268 ± 0.161  ms/op
   ```


----------------------------------------------------------------
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.

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