Compute Library
 23.11
CLNormalizationLayer.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017-2021 Arm Limited.
3  *
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  */
24 
26 
27 #include "arm_compute/core/Error.h"
30 #include "arm_compute/core/Types.h"
33 
34 #include "src/common/utils/Log.h"
37 
38 namespace arm_compute
39 {
41  : _norm_kernel(std::make_unique<CLNormalizationLayerKernel>()),
42  _border_handler(std::make_unique<CLFillBorderKernel>())
43 {
44 }
45 
47 
49 {
50  configure(CLKernelLibrary::get().get_compile_context(), input, output, norm_info);
51 }
52 
55  ICLTensor *output,
56  const NormalizationLayerInfo &norm_info)
57 {
58  ARM_COMPUTE_ERROR_ON(input == nullptr);
59  ARM_COMPUTE_LOG_PARAMS(input, output, norm_info);
60 
61  // Configure normalization kernel
62  _norm_kernel->configure(compile_context, input, output, norm_info);
63 
64  if (!_norm_kernel->border_size().empty())
65  {
66  // Fill the border by 3 elements since we need vload4 in the IN_MAP normalization kernel
67  _border_handler->configure(compile_context, input, _norm_kernel->border_size(), BorderMode::CONSTANT,
68  PixelValue());
69  }
70 }
71 
73  const ITensorInfo *output,
74  const NormalizationLayerInfo &norm_info)
75 {
76  return CLNormalizationLayerKernel::validate(input, output, norm_info);
77 }
78 
80 {
81  if (!_norm_kernel->border_size().empty())
82  {
83  // Run border handler
84  CLScheduler::get().enqueue(*_border_handler, false);
85  }
86 
87  // Run normalization kernel
88  CLScheduler::get().enqueue(*_norm_kernel);
89 }
90 } // namespace arm_compute
arm_compute::CLNormalizationLayerKernel::validate
static Status validate(const ITensorInfo *input, const ITensorInfo *output, NormalizationLayerInfo norm_info)
Static function to check if given info will lead to a valid configuration of CLNormalizationLayerKern...
Definition: CLNormalizationLayerKernel.cpp:243
arm_compute::BorderMode::CONSTANT
@ CONSTANT
Pixels outside the image are assumed to have a constant value.
arm_compute::CLNormalizationLayer::validate
static Status validate(const ITensorInfo *input, const ITensorInfo *output, const NormalizationLayerInfo &norm_info)
Static function to check if given info will lead to a valid configuration of CLNormalizationLayer.
Definition: CLNormalizationLayer.cpp:72
CLNormalizationLayer.h
arm_compute::PixelValue
Class describing the value of a pixel for any image format.
Definition: PixelValue.h:35
CLNormalizationLayerKernel.h
arm_compute::CLScheduler::enqueue
void enqueue(ICLKernel &kernel, bool flush=true)
Schedule the execution of the passed kernel if possible.
Definition: CLScheduler.cpp:232
arm_compute::CLNormalizationLayerKernel
Interface for the normalization layer kernel.
Definition: CLNormalizationLayerKernel.h:35
Types.h
arm_compute::CLNormalizationLayer::configure
void configure(ICLTensor *input, ICLTensor *output, const NormalizationLayerInfo &norm_info)
Set the input and output tensors.
Definition: CLNormalizationLayer.cpp:48
arm_compute::ICLTensor
Interface for OpenCL tensor.
Definition: ICLTensor.h:41
TensorInfo.h
arm_compute::CLFillBorderKernel
Interface for filling the border of a kernel.
Definition: CLFillBorderKernel.h:37
Error.h
arm_compute::CLKernelLibrary::get
static CLKernelLibrary & get()
Access the KernelLibrary singleton.
Definition: CLKernelLibrary.cpp:41
arm_compute::CLNormalizationLayer::~CLNormalizationLayer
~CLNormalizationLayer()
Default destructor.
ARM_COMPUTE_ERROR_ON
#define ARM_COMPUTE_ERROR_ON(cond)
If the condition is true then an error message is printed and an exception thrown.
Definition: Error.h:466
arm_compute::CLCompileContext
CLCompileContext class.
Definition: CLCompileContext.h:204
CLFillBorderKernel.h
arm_compute::Status
Status class.
Definition: Error.h:52
CLScheduler.h
Interface to enqueue OpenCL kernels and get/set the OpenCL CommandQueue and ICLTuner.
arm_compute::CLNormalizationLayer::run
void run() override
Run the kernels contained in the function.
Definition: CLNormalizationLayer.cpp:79
PixelValue.h
arm_compute::CLScheduler::get
static CLScheduler & get()
Access the scheduler singleton.
Definition: CLScheduler.cpp:112
arm_compute::NormalizationLayerInfo
Normalization Layer Information class.
Definition: Types.h:1529
arm_compute
Copyright (c) 2017-2023 Arm Limited.
Definition: introduction.dox:24
Log.h
arm_compute::ITensorInfo
Store the tensor's metadata.
Definition: ITensorInfo.h:44
arm_compute::CLNormalizationLayer::CLNormalizationLayer
CLNormalizationLayer()
Default constructor.
Definition: CLNormalizationLayer.cpp:40
ARM_COMPUTE_LOG_PARAMS
#define ARM_COMPUTE_LOG_PARAMS(...)
Definition: Log.h:35
Validate.h
arm_compute::test::validation::input
auto input
Definition: LSTMLayerQuantized.cpp:486