Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Signed-off-by: Heemin Kim <[email protected]>
  • Loading branch information
heemin32 authored Jul 25, 2024
1 parent bd5b633 commit c8ec49f
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,13 @@ public void init(final long totalLiveDocs) {
public void transfer(final BytesRef bytesRef) {
dimension = bytesRef.length * 8;
if (vectorsPerTransfer == Integer.MIN_VALUE) {
vectorsPerTransfer = (bytesRef.length * totalLiveDocs) / vectorsStreamingMemoryLimit;
// This condition comes if vectorsStreamingMemoryLimit is higher than total number floats to transfer
// Doing this will reduce 1 extra trip to JNI layer.
// if vectorsStreamingMemoryLimit is 100 bytes and we have 50 vectors with length of 5, then per
// transfer we have to send 100/5 => 20 vectors.
vectorsPerTransfer = vectorsStreamingMemoryLimit / bytesRef.length;
// If vectorsPerTransfer comes out to be 0, then we set number of vectors per transfer to 1, to ensure that
// we are sending minimum number of vectors.
if (vectorsPerTransfer == 0) {
vectorsPerTransfer = totalLiveDocs;
vectorsPerTransfer = 1;
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,11 +38,13 @@ public void transfer(final BytesRef bytesRef) {
dimension = vector.length;

if (vectorsPerTransfer == Integer.MIN_VALUE) {
vectorsPerTransfer = (dimension * Float.BYTES * totalLiveDocs) / vectorsStreamingMemoryLimit;
// This condition comes if vectorsStreamingMemoryLimit is higher than total number floats to transfer
// Doing this will reduce 1 extra trip to JNI layer.
// if vectorsStreamingMemoryLimit is 100 bytes and we have 50 vectors with 5 dimension, then per
// transfer we have to send 100/(5 * 4) => 5 vectors.
vectorsPerTransfer = vectorsStreamingMemoryLimit / ((long) dimension * Float.BYTES);
// If vectorsPerTransfer comes out to be 0, then we set number of vectors per transfer to 1, to ensure that
// we are sending minimum number of vectors.
if (vectorsPerTransfer == 0) {
vectorsPerTransfer = totalLiveDocs;
vectorsPerTransfer = 1;
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ public class VectorTransferByteTests extends TestCase {
public void testTransfer_whenCalled_thenAdded() {
final BytesRef bytesRef1 = getByteArrayOfVectors(20);
final BytesRef bytesRef2 = getByteArrayOfVectors(20);
VectorTransferByte vectorTransfer = new VectorTransferByte(1000);
VectorTransferByte vectorTransfer = new VectorTransferByte(40);
try {
vectorTransfer.init(2);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ public class VectorTransferFloatTests extends TestCase {
public void testTransfer_whenCalled_thenAdded() {
final BytesRef bytesRef1 = getByteArrayOfVectors(20);
final BytesRef bytesRef2 = getByteArrayOfVectors(20);
VectorTransferFloat vectorTransfer = new VectorTransferFloat(1000);
VectorTransferFloat vectorTransfer = new VectorTransferFloat(160);
try {
vectorTransfer.init(2);

Expand Down

0 comments on commit c8ec49f

Please sign in to comment.