23.11
generic.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2020, 2023 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
25
#include <cstdint>
26
#include <cstring>
27
#ifdef ARM_COMPUTE_ENABLE_BF16
28
#include "
bfloat.hpp
"
29
using
arm_gemm::bfloat16
;
30
#endif
31
32
namespace
arm_conv
{
33
namespace
pooling
{
34
35
template
<
typename
T>
36
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(
37
uint64_t,
38
uint64_t,
39
const
uint64_t n_channels,
40
const
T *
const
*
const
inptrs,
41
T *outptr
42
)
43
{
44
std::memcpy(outptr, inptrs[0], n_channels *
sizeof
(T));
45
}
46
47
template
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(uint64_t, uint64_t, uint64_t,
const
float
*
const
*,
float
*);
48
49
#ifdef __ARM_FP16_ARGS
50
template
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(uint64_t, uint64_t, uint64_t,
const
__fp16 *
const
*, __fp16 *);
51
#endif
52
53
#ifdef ARM_COMPUTE_ENABLE_BF16
54
template
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(uint64_t, uint64_t, uint64_t,
const
bfloat16
*
const
*,
bfloat16
*);
55
#endif
56
57
template
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(uint64_t, uint64_t, uint64_t,
const
int8_t *
const
*, int8_t *);
58
template
void
cpp_nhwc_1x1_stride_any_depthfirst_impl
(uint64_t, uint64_t, uint64_t,
const
uint8_t *
const
*, uint8_t *);
59
60
}
// namespace pooling
61
}
// namespace arm_conv
arm_conv::pooling::pooling
template UniquePoolingCommon< float, float > pooling(const PoolingArgs &, const Nothing &)
arm_conv::pooling::cpp_nhwc_1x1_stride_any_depthfirst_impl
void cpp_nhwc_1x1_stride_any_depthfirst_impl(uint64_t, uint64_t, const uint64_t n_channels, const T *const *const inptrs, T *outptr)
Definition:
generic.cpp:36
arm_gemm::bfloat16
arm_compute::bfloat16 bfloat16
Definition:
bfloat.hpp:30
arm_conv
Definition:
addressing.cpp:30
bfloat.hpp
src
core
NEON
kernels
arm_conv
pooling
kernels
cpp_nhwc_1x1_stride_any_depthfirst
generic.cpp
Generated on Tue Nov 21 2023 16:31:01 for Compute Library by
1.8.17