in ndarray/src/main/java/org/tensorflow/ndarray/impl/buffer/raw/FloatRawDataBuffer.java [64:98]
public FloatDataBuffer copyTo(DataBuffer<Float> dst, long size) {
Validator.copyToArgs(this, dst, size);
return dst.accept(new DataStorageVisitor<FloatDataBuffer>() {
@Override
public FloatDataBuffer visit(FloatBuffer buffer) {
if (buffer.hasArray()) {
memory.copyTo(UnsafeMemoryHandle.fromArray(buffer.array(), buffer.position(), buffer.limit()), size);
} else if (memory.isArray()) {
buffer.put(memory.toArrayFloatBuffer());
} else {
slowCopyTo(dst, size);
}
return FloatRawDataBuffer.this;
}
@Override
public FloatDataBuffer visit(long address, long length, long scale) {
memory.copyTo(UnsafeMemoryHandle.fromAddress(address, length, scale), size);
return FloatRawDataBuffer.this;
}
@Override
public FloatDataBuffer fallback() {
if (dst instanceof FloatDataBuffer) {
FloatDataBuffer floatDst = (FloatDataBuffer)dst;
for (long idx = 0L; idx < size; ++idx) {
floatDst.setFloat(getFloat(idx), idx);
}
return FloatRawDataBuffer.this;
}
return slowCopyTo(dst, size);
}
});
}