aboutsummaryrefslogtreecommitdiff
path: root/src/backends/reference/workloads/Pooling2d.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/backends/reference/workloads/Pooling2d.cpp')
-rw-r--r--src/backends/reference/workloads/Pooling2d.cpp14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/backends/reference/workloads/Pooling2d.cpp b/src/backends/reference/workloads/Pooling2d.cpp
index 5812a290e7..9890920113 100644
--- a/src/backends/reference/workloads/Pooling2d.cpp
+++ b/src/backends/reference/workloads/Pooling2d.cpp
@@ -143,12 +143,16 @@ void Pooling2d(const float* in,
const TensorInfo& outputInfo,
const Pooling2dDescriptor& params)
{
+ const unsigned int channelsIndex = params.m_DataLayout.GetChannelsIndex();
+ const unsigned int heightIndex = params.m_DataLayout.GetHeightIndex();
+ const unsigned int widthIndex = params.m_DataLayout.GetWidthIndex();
+
const int batchSize = boost::numeric_cast<int>(outputInfo.GetShape()[0]);
- const int channels = boost::numeric_cast<int>(outputInfo.GetShape()[1]);
- const int heightOutput = boost::numeric_cast<int>(outputInfo.GetShape()[2]);
- const int widthOutput = boost::numeric_cast<int>(outputInfo.GetShape()[3]);
- const int heightInput = boost::numeric_cast<int>(inputInfo.GetShape()[2]);
- const int widthInput = boost::numeric_cast<int>(inputInfo.GetShape()[3]);
+ const int channels = boost::numeric_cast<int>(outputInfo.GetShape()[channelsIndex]);
+ const int heightOutput = boost::numeric_cast<int>(outputInfo.GetShape()[heightIndex]);
+ const int widthOutput = boost::numeric_cast<int>(outputInfo.GetShape()[widthIndex]);
+ const int heightInput = boost::numeric_cast<int>(inputInfo.GetShape()[heightIndex]);
+ const int widthInput = boost::numeric_cast<int>(inputInfo.GetShape()[widthIndex]);
const int padLeft = boost::numeric_cast<int>(params.m_PadLeft);
const int padRight = boost::numeric_cast<int>(params.m_PadRight);
const int padTop = boost::numeric_cast<int>(params.m_PadTop);