blob: ee77d58052bf4f04fbcd3193ea3b49e2a49ec699 [file] [log] [blame]
Georgios Pinitas28705162018-03-21 20:10:53 +00001/*
Michele Di Giorgiod9eaf612020-07-08 11:12:57 +01002 * Copyright (c) 2018-2020 Arm Limited.
Georgios Pinitas28705162018-03-21 20:10:53 +00003 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
Georgios Pinitasd9eb2752018-04-03 13:44:29 +010024#include "arm_compute/graph/backends/CL/CLNodeValidator.h"
Georgios Pinitas28705162018-03-21 20:10:53 +000025
Georgios Pinitasd9eb2752018-04-03 13:44:29 +010026#include "arm_compute/graph/backends/ValidateHelpers.h"
27#include "arm_compute/graph/nodes/Nodes.h"
Georgios Pinitas28705162018-03-21 20:10:53 +000028
29#include "arm_compute/core/utils/misc/Cast.h"
30#include "arm_compute/runtime/CL/CLFunctions.h"
Isabella Gottardi7234ed82018-11-27 08:51:10 +000031#include "arm_compute/runtime/CPP/CPPFunctions.h"
Georgios Pinitas28705162018-03-21 20:10:53 +000032
33using namespace arm_compute::utils::cast;
34
35namespace arm_compute
36{
Georgios Pinitasd9eb2752018-04-03 13:44:29 +010037namespace graph
Georgios Pinitas28705162018-03-21 20:10:53 +000038{
39namespace backends
40{
Sheri Zhang16dddd22020-05-27 15:03:48 +010041/** Collection of CL element-wise functions */
42struct CLEltwiseLayerFunctions
43{
44 using ArithmeticAddition = CLArithmeticAddition;
45 using ArithmeticSubtraction = CLArithmeticSubtraction;
46 using PixelWiseMultiplication = CLPixelWiseMultiplication;
thecha01f8e35842020-07-28 17:28:17 +010047 using ElementwiseMax = CLElementwiseMax;
Sheri Zhang16dddd22020-05-27 15:03:48 +010048};
49
50/** Collection of CL unary element-wise functions */
51struct CLUnaryEltwiseLayerFunctions
52{
53 using ExpLayer = CLExpLayer;
54};
55
Georgios Pinitas28705162018-03-21 20:10:53 +000056Status CLNodeValidator::validate(INode *node)
57{
58 if(node == nullptr)
59 {
60 return Status{};
61 }
62
63 NodeType type = node->type();
64 switch(type)
65 {
Manuel Bottinid2048ce2018-10-23 17:00:42 +010066 case NodeType::BoundingBoxTransformLayer:
67 return detail::validate_bounding_box_transform_layer<CLBoundingBoxTransform>(*polymorphic_downcast<BoundingBoxTransformLayerNode *>(node));
Georgios Pinitas087eaf62018-05-16 15:52:35 +010068 case NodeType::ChannelShuffleLayer:
69 return detail::validate_channel_shuffle_layer<CLChannelShuffleLayer>(*polymorphic_downcast<ChannelShuffleLayerNode *>(node));
Georgios Pinitas28705162018-03-21 20:10:53 +000070 case NodeType::ConvolutionLayer:
71 return detail::validate_convolution_layer<CLConvolutionLayer,
72 CLDirectConvolutionLayer,
73 CLGEMMConvolutionLayer,
74 CLWinogradConvolutionLayer>(*polymorphic_downcast<ConvolutionLayerNode *>(node));
thecha010a05e6a2020-08-28 18:40:38 +010075 case NodeType::DepthToSpaceLayer:
76 return detail::validate_depth_to_space_layer<CLDepthToSpaceLayer>(*polymorphic_downcast<DepthToSpaceLayerNode *>(node));
Georgios Pinitas28705162018-03-21 20:10:53 +000077 case NodeType::DepthwiseConvolutionLayer:
Manuel Bottini05069f02019-09-26 17:18:26 +010078 return detail::validate_depthwise_convolution_layer<CLDepthwiseConvolutionLayer>(*polymorphic_downcast<DepthwiseConvolutionLayerNode *>(node));
Isabella Gottardicd4e9ab2019-11-05 17:50:27 +000079 case NodeType::DequantizationLayer:
80 return detail::validate_dequantization_layer<CLDequantizationLayer>(*polymorphic_downcast<DequantizationLayerNode *>(node));
Isabella Gottardi7234ed82018-11-27 08:51:10 +000081 case NodeType::DetectionOutputLayer:
82 return detail::validate_detection_output_layer<CPPDetectionOutputLayer>(*polymorphic_downcast<DetectionOutputLayerNode *>(node));
Isabella Gottardia7acb3c2019-01-08 13:48:44 +000083 case NodeType::DetectionPostProcessLayer:
84 return detail::validate_detection_post_process_layer<CPPDetectionPostProcessLayer>(*polymorphic_downcast<DetectionPostProcessLayerNode *>(node));
Manuel Bottini5209be52019-02-13 16:34:56 +000085 case NodeType::GenerateProposalsLayer:
86 return detail::validate_generate_proposals_layer<CLGenerateProposalsLayer>(*polymorphic_downcast<GenerateProposalsLayerNode *>(node));
Michele Di Giorgio555d1102018-09-12 13:51:59 +010087 case NodeType::NormalizePlanarYUVLayer:
88 return detail::validate_normalize_planar_yuv_layer<CLNormalizePlanarYUVLayer>(*polymorphic_downcast<NormalizePlanarYUVLayerNode *>(node));
Michele Di Giorgio4bb17332018-09-26 13:56:51 +010089 case NodeType::PadLayer:
90 return detail::validate_pad_layer<CLPadLayer>(*polymorphic_downcast<PadLayerNode *>(node));
Georgios Pinitas57c48242018-08-02 13:41:49 +010091 case NodeType::PermuteLayer:
92 return detail::validate_permute_layer<CLPermute>(*polymorphic_downcast<PermuteLayerNode *>(node));
Georgios Pinitasf8c47492020-02-04 17:39:59 +000093 case NodeType::PReluLayer:
94 return detail::validate_prelu_layer<CLPReluLayer>(*polymorphic_downcast<PReluLayerNode *>(node));
Pablo Tello32521432018-11-15 14:43:10 +000095 case NodeType::PriorBoxLayer:
96 return detail::validate_priorbox_layer<CLPriorBoxLayer>(*polymorphic_downcast<PriorBoxLayerNode *>(node));
Isabella Gottardi3db1ba92019-05-17 12:35:20 +010097 case NodeType::QuantizationLayer:
98 return detail::validate_quantization_layer<CLQuantizationLayer>(*polymorphic_downcast<QuantizationLayerNode *>(node));
Gian Marco Iodice23e24792018-09-07 15:32:14 +010099 case NodeType::ReorgLayer:
100 return detail::validate_reorg_layer<CLReorgLayer>(*polymorphic_downcast<ReorgLayerNode *>(node));
Isabella Gottardi0ae5de92019-03-14 10:32:11 +0000101 case NodeType::ReshapeLayer:
102 return detail::validate_reshape_layer<CLReshapeLayer>(*polymorphic_downcast<ReshapeLayerNode *>(node));
Manuel Bottini3f9d4d72018-10-19 14:04:42 +0100103 case NodeType::ROIAlignLayer:
104 return detail::validate_roi_align_layer<CLROIAlignLayer>(*polymorphic_downcast<ROIAlignLayerNode *>(node));
Michele Di Giorgioc30b6682018-09-12 17:44:08 +0100105 case NodeType::SliceLayer:
106 return detail::validate_slice_layer<CLSlice>(*polymorphic_downcast<SliceLayerNode *>(node));
Michalis Spyrou4e1c3f32018-09-20 17:14:03 +0100107 case NodeType::UpsampleLayer:
108 return detail::validate_upsample_layer<CLUpsampleLayer>(*polymorphic_downcast<UpsampleLayerNode *>(node));
Michalis Spyrou96f67692018-09-13 11:39:28 +0100109 case NodeType::YOLOLayer:
110 return detail::validate_yolo_layer<CLYOLOLayer>(*polymorphic_downcast<YOLOLayerNode *>(node));
Sheri Zhang16dddd22020-05-27 15:03:48 +0100111 case NodeType::EltwiseLayer:
112 return detail::validate_eltwise_Layer<CLEltwiseLayerFunctions>(*polymorphic_downcast<EltwiseLayerNode *>(node));
113 case NodeType::UnaryEltwiseLayer:
114 return detail::validate_unary_eltwise_layer<CLUnaryEltwiseLayerFunctions>(*polymorphic_downcast<UnaryEltwiseLayerNode *>(node));
Georgios Pinitas28705162018-03-21 20:10:53 +0000115 default:
116 return Status{};
117 }
118}
119} // namespace backends
Georgios Pinitasd9eb2752018-04-03 13:44:29 +0100120} // namespace graph
Michele Di Giorgio555d1102018-09-12 13:51:59 +0100121} // namespace arm_compute