24.02.1
NEFillBorder.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2016-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
#ifndef ARM_COMPUTE_NEFILLBORDER_H
25
#define ARM_COMPUTE_NEFILLBORDER_H
26
27
#include "
arm_compute/core/PixelValue.h
"
28
#include "
arm_compute/core/Types.h
"
29
#include "
arm_compute/runtime/IFunction.h
"
30
31
#include <memory>
32
33
namespace
arm_compute
34
{
35
// Forward declaration
36
class
ITensor;
37
class
NEFillBorderKernel;
38
39
/** Basic function to run @ref NEFillBorderKernel */
40
class
NEFillBorder
:
public
IFunction
41
{
42
public
:
43
NEFillBorder
();
44
/** Initialize the function's source, destination and border_mode.
45
*
46
* Valid data layouts:
47
* - All
48
*
49
* Valid data type configurations:
50
* |src |dst |
51
* |:--------------|:--------------|
52
* |All |All |
53
*
54
* @note This function fills the borders within the XY-planes.
55
*
56
* @param[in, out] input Source tensor. Data type supported: All
57
* @param[in] border_width Width of the tensor border in pixels.
58
* @param[in] border_mode Strategy to use for borders.
59
* @param[in] constant_border_value (Optional) Constant value to use for borders if border_mode is set to CONSTANT.
60
*/
61
void
configure
(
ITensor
*
input
,
62
unsigned
int
border_width,
63
BorderMode
border_mode,
64
const
PixelValue
&constant_border_value =
PixelValue
());
65
66
// Inherited methods overridden:
67
void
run
()
override
;
68
69
private
:
70
std::unique_ptr<NEFillBorderKernel> _border_handler;
/**< Kernel to handle image borders */
71
};
72
}
// namespace arm_compute
73
#endif
/*ARM_COMPUTE_NEFILLBORDER_H */
arm_compute::PixelValue
Class describing the value of a pixel for any image format.
Definition:
PixelValue.h:35
arm_compute::IFunction
Base class for all functions.
Definition:
IFunction.h:30
Types.h
arm_compute::NEFillBorder
Basic function to run NEFillBorderKernel.
Definition:
NEFillBorder.h:40
arm_compute::ITensor
Interface for CPU tensor.
Definition:
ITensor.h:36
arm_compute::NEFillBorder::run
void run() override
Run the kernels contained in the function.
Definition:
NEFillBorder.cpp:48
PixelValue.h
IFunction.h
arm_compute
Copyright (c) 2017-2024 Arm Limited.
Definition:
introduction.dox:24
arm_compute::NEFillBorder::NEFillBorder
NEFillBorder()
Definition:
NEFillBorder.cpp:34
arm_compute::NEFillBorder::configure
void configure(ITensor *input, unsigned int border_width, BorderMode border_mode, const PixelValue &constant_border_value=PixelValue())
Initialize the function's source, destination and border_mode.
Definition:
NEFillBorder.cpp:38
arm_compute::BorderMode
BorderMode
Methods available to handle borders.
Definition:
Types.h:231
arm_compute::test::validation::input
auto input
Definition:
LSTMLayerQuantized.cpp:486
arm_compute
runtime
NEON
functions
NEFillBorder.h
Generated on Mon Mar 18 2024 11:31:56 for Compute Library by
1.8.17