Skip to content
Snippets Groups Projects
Commit 1671c0a4 authored by Olivier BICHLER's avatar Olivier BICHLER Committed by Maxence Naud
Browse files

Minimize number of copy call

parent 5a0fd94c
No related branches found
No related tags found
No related merge requests found
...@@ -63,15 +63,31 @@ void Aidge::Slice_OpImpl::forward() { ...@@ -63,15 +63,31 @@ void Aidge::Slice_OpImpl::forward() {
prodInputDims[nbDims - i] = prodInputDims[nbDims - i + 1] * inputDims[nbDims - i]; prodInputDims[nbDims - i] = prodInputDims[nbDims - i + 1] * inputDims[nbDims - i];
} }
std::size_t j = 0; std::size_t i = beginning;
std::size_t i = 0; std::size_t size = 0;
for (; j < prodSlicedDims[0];) { std::size_t offset = 0;
op.getOutput(0)->getImpl()->copy(op.getInput(0)->getImpl()->rawPtr(beginning + i), 1, j); for (std::size_t j = 0; j < prodSlicedDims[0];) {
++size;
++i; ++i;
++j; ++j;
bool newChunk = false;
for (std::size_t idx = nbDims - 1; idx > 0; --idx) { for (std::size_t idx = nbDims - 1; idx > 0; --idx) {
i += j % prodSlicedDims[idx] == 0 ? substractedDims[idx] * prodInputDims[idx + 1] : 0; if (j % prodSlicedDims[idx] == 0) {
i += substractedDims[idx] * prodInputDims[idx + 1];
newChunk = true;
}
} }
if (newChunk) {
op.getOutput(0)->getImpl()->copy(op.getInput(0)->getImpl()->rawPtr(beginning), size, offset);
beginning = i;
offset += size;
size = 0;
}
}
if (size > 0) {
op.getOutput(0)->getImpl()->copy(op.getInput(0)->getImpl()->rawPtr(beginning), size, offset);
} }
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment