ArmNN
 22.05
Convolution3dLayer.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "Convolution3dLayer.hpp"
7 #include "LayerCloneBase.hpp"
8 
10 
12 
13 using namespace armnnUtils;
14 
15 namespace armnn
16 {
17 
19  : LayerWithParameters(param.GetNumInputs(), 1, LayerType::Convolution3d, param, name)
20 {
21 }
22 
24 {
25  const std::vector<TensorShape>& inputShapes =
26  {
29  };
30 
31  // Conv3d Filter Layout: [D,H,W,I,O]
32  const TensorShape filterShape = inputShapes[1];
33  unsigned int filterDepth = filterShape[0];
34  unsigned int filterHeight = filterShape[1];
35  unsigned int filterWidth = filterShape[2];
36  unsigned int inChannels = filterShape[3];
37  unsigned int outChannels = filterShape[4];
38 
39  fn("FilterDepth",std::to_string(filterDepth));
40  fn("FilterHeight",std::to_string(filterHeight));
41  fn("FilterWidth",std::to_string(filterWidth));
42  fn("InputChannels",std::to_string(inChannels));
43  fn("OutputChannels",std::to_string(outChannels));
44 
46 }
47 
48 std::unique_ptr<IWorkload> Convolution3dLayer::CreateWorkload(const IWorkloadFactory& factory) const
49 {
51  SetAdditionalInfo(descriptor);
52 
53  return factory.CreateWorkload(LayerType::Convolution3d, descriptor, PrepInfoAndDesc(descriptor));
54 }
55 
57 {
58  auto layer = CloneBase<Convolution3dLayer>(graph, m_Param, GetName());
59  return std::move(layer);
60 }
61 
62 std::vector<TensorShape> Convolution3dLayer::InferOutputShapes(const std::vector<TensorShape>& inputShapes) const
63 {
64  ARMNN_ASSERT(inputShapes.size() == 2);
65  const TensorShape& inputShape = inputShapes[0];
66  const TensorShape& filterShape = inputShapes[1];
67 
68  ARMNN_ASSERT_MSG(inputShape.GetNumDimensions() == 5, "Convolutions will always have 5D input.");
69 
73 
74  DataLayoutIndexed dataLayoutIndex(m_Param.m_DataLayout);
75 
76  unsigned int inWidth = inputShape[dataLayoutIndex.GetWidthIndex()];
77  unsigned int inHeight = inputShape[dataLayoutIndex.GetHeightIndex()];
78  unsigned int inDepth = inputShape[dataLayoutIndex.GetDepthIndex()];
79  unsigned int inBatchSize = inputShape[0];
80 
81  // Conv3d Filter Layout: [D,H,W,I,O]
82  unsigned int filterDepth = filterShape[0];
83  unsigned int dilatedFilterDepth = filterDepth + (m_Param.m_DilationZ - 1) * (filterDepth - 1);
84  unsigned int readDepth = (inDepth + m_Param.m_PadFront + m_Param.m_PadBack) - dilatedFilterDepth;
85  unsigned int outDepth = 1 + (readDepth / m_Param.m_StrideZ);
86 
87  unsigned int filterHeight = filterShape[1];
88  unsigned int dilatedFilterHeight = filterHeight + (m_Param.m_DilationY - 1) * (filterHeight - 1);
89  unsigned int readHeight = (inHeight + m_Param.m_PadTop + m_Param.m_PadBottom) - dilatedFilterHeight;
90  unsigned int outHeight = 1 + (readHeight / m_Param.m_StrideY);
91 
92  unsigned int filterWidth = filterShape[2];
93  unsigned int dilatedFilterWidth = filterWidth + (m_Param.m_DilationX - 1) * (filterWidth - 1);
94  unsigned int readWidth = (inWidth + m_Param.m_PadLeft + m_Param.m_PadRight) - dilatedFilterWidth;
95  unsigned int outWidth = 1 + (readWidth / m_Param.m_StrideX);
96 
97  unsigned int outChannels = filterShape[4];
98  unsigned int outBatchSize = inBatchSize;
99 
101  TensorShape( { outBatchSize, outDepth, outHeight, outWidth, outChannels } ) :
102  TensorShape( { outBatchSize, outChannels, outDepth, outHeight, outWidth });
103 
104  return std::vector<TensorShape>({ tensorShape });
105 }
106 
108 {
110 
111  const TensorShape& outputShape = GetOutputSlot(0).GetTensorInfo().GetShape();
112 
114 
115  ARMNN_ASSERT_MSG(GetInputSlot(1).GetConnection(),
116  "Convolution3dLayer: Weights should be connected to input slot 1.");
117 
118  auto inferredShapes = InferOutputShapes({
121 
122  ARMNN_ASSERT(inferredShapes.size() == 1);
123 
124  ValidateAndCopyShape(outputShape, inferredShapes[0], m_ShapeInferenceMethod, "Convolution3dLayer");
125 }
126 
128 void Convolution3dLayer::Accept(ILayerVisitor& visitor) const
129 {
130  IgnoreUnused(visitor);
131  throw armnn::Exception("Convolution3dLayer: VisitConvolution3dLayer is not implemented");
132 }
134 
136 {
137  strategy.ExecuteStrategy(this, GetParameters(), {}, GetName());
138 }
139 
140 } // namespace armnn
virtual std::unique_ptr< IWorkload > CreateWorkload(const IWorkloadFactory &factory) const override
Makes a workload for the Convolution3d type.
Convolution3dDescriptor m_Param
The parameters for the layer (not including tensor-valued weights etc.).
unsigned int GetWidthIndex() const
const TensorShape & GetShape() const
Definition: Tensor.hpp:191
uint32_t m_PadBack
Padding back value in the depth dimension.
#define ARMNN_NO_DEPRECATE_WARN_BEGIN
Definition: Deprecated.hpp:33
uint32_t m_StrideX
Stride value when proceeding through input for the width dimension.
virtual void ExecuteStrategy(const armnn::IConnectableLayer *layer, const armnn::BaseDescriptor &descriptor, const std::vector< armnn::ConstTensor > &constants, const char *name, const armnn::LayerBindingId id=0)=0
std::vector< TensorShape > InferOutputShapes(const std::vector< TensorShape > &inputShapes) const override
By default returns inputShapes if the number of inputs are equal to number of outputs, otherwise infers the output shapes from given input shapes and layer properties.
void SerializeLayerParameters(ParameterStringifyFunction &fn) const override
Helper to serialize the layer parameters to string (currently used in DotSerializer and company)...
uint32_t m_PadBottom
Padding bottom value in the height dimension.
unsigned int GetDepthIndex() const
void VerifyShapeInferenceType(const TensorShape &outputShape, ShapeInferenceMethod shapeInferenceMethod)
Definition: Layer.cpp:491
Copyright (c) 2021 ARM Limited and Contributors.
const Convolution3dDescriptor & GetParameters() const override
void IgnoreUnused(Ts &&...)
const IOutputSlot * GetConnection() const override
Definition: Layer.hpp:204
uint32_t m_DilationX
Dilation along x axis.
void ValidateAndCopyShape(const TensorShape &outputShape, const TensorShape &inferredShape, const ShapeInferenceMethod shapeInferenceMethod, const std::string &layerName, const unsigned int outputSlotIndex=0)
Definition: Layer.cpp:422
unsigned int GetHeightIndex() const
uint32_t m_StrideY
Stride value when proceeding through input for the height dimension.
ARMNN_NO_DEPRECATE_WARN_END void ExecuteStrategy(IStrategy &strategy) const override
Apply a visitor to this layer.
void SerializeLayerParameters(ParameterStringifyFunction &fn) const override
Helper to serialize the layer parameters to string.
void VerifyLayerConnections(unsigned int expectedConnections, const CheckLocation &location) const
Definition: Layer.cpp:378
const InputSlot & GetInputSlot(unsigned int index) const override
Get a const input slot handle by slot index.
Definition: Layer.hpp:322
ARMNN_NO_DEPRECATE_WARN_BEGIN void Accept(ILayerVisitor &visitor) const override
uint32_t GetNumInputs(bool biasEnabled)
#define ARMNN_NO_DEPRECATE_WARN_END
Definition: Deprecated.hpp:34
#define ARMNN_ASSERT_MSG(COND, MSG)
Definition: Assert.hpp:15
Provides access to the appropriate indexes for Channels, Height and Width based on DataLayout...
Convolution3dLayer * Clone(Graph &graph) const override
Creates a dynamically-allocated copy of this layer.
#define ARMNN_ASSERT(COND)
Definition: Assert.hpp:14
uint32_t m_PadFront
Padding front value in the depth dimension.
#define CHECK_LOCATION()
Definition: Exceptions.hpp:203
uint32_t m_PadLeft
Padding left value in the width dimension.
A Convolution3dDescriptor for the Convolution3dLayer.
uint32_t m_PadRight
Padding right value in the width dimension.
void SetAdditionalInfo(QueueDescriptor &descriptor) const
Definition: Layer.cpp:274
DataLayout m_DataLayout
The data layout to be used (NDHWC, NCDHW).
Convolution3dLayer(const Convolution3dDescriptor &param, const char *name)
Constructor to create a Convolution3dLayer.
Base class for all ArmNN exceptions so that users can filter to just those.
Definition: Exceptions.hpp:46
uint32_t m_PadTop
Padding top value in the height dimension.
void ValidateTensorShapesFromInputs() override
Check if the input tensor shape(s) will lead to a valid configuration of Convolution3dLayer.
WorkloadInfo PrepInfoAndDesc(QueueDescriptor &descriptor) const
Helper function to reduce duplication in *LayerCreateWorkload.
const OutputSlot & GetOutputSlot(unsigned int index=0) const override
Get the const output slot handle by slot index.
Definition: Layer.hpp:324
virtual const TensorInfo & GetTensorInfo() const =0
uint32_t GetNumInputs() const
Get the number of views/inputs.
const char * GetName() const override
Returns the name of the layer.
Definition: Layer.hpp:317
This layer represents a convolution 3d operation.
std::function< void(const std::string &name, const std::string &value)> ParameterStringifyFunction
virtual std::unique_ptr< IWorkload > CreateWorkload(LayerType type, const QueueDescriptor &descriptor, const WorkloadInfo &info) const
const TensorInfo & GetTensorInfo() const override
Definition: Layer.cpp:92
uint32_t m_DilationZ
Dilation along z axis.
uint32_t m_StrideZ
Stride value when proceeding through input for the depth dimension.
ShapeInferenceMethod m_ShapeInferenceMethod
Definition: Layer.hpp:421
uint32_t m_DilationY
Dilation along y axis.
LayerType
When adding a new layer, adapt also the LastLayer enum value in the enum class LayerType below...
Definition: Types.hpp:467