ONE - On-device Neural Engine
Toggle main menu visibility
Main Page
Related Pages
Topics
Namespaces
Namespace List
Namespace Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
y
z
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
z
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
w
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Enumerations
a
b
c
d
e
f
i
k
l
m
n
o
p
q
r
s
t
u
Enumerator
a
b
c
d
e
f
g
i
k
l
m
n
o
p
r
s
u
v
w
y
Data Structures
Data Structures
Data Structure Index
Class Hierarchy
Data Fields
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
z
Enumerations
a
c
d
e
f
g
i
k
l
m
o
p
r
s
t
w
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
Related Symbols
a
b
c
d
e
f
g
h
i
m
n
o
p
r
s
t
u
v
w
Files
File List
Globals
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
Variables
_
b
c
d
f
g
i
k
m
n
o
p
s
t
v
Typedefs
a
d
f
g
i
l
m
n
o
s
t
u
v
Enumerations
f
g
n
o
p
r
Enumerator
a
k
n
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Examples
•
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
Loading...
Searching...
No Matches
DepthwiseConvolutionLayer.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2024 Samsung Electronics Co., Ltd. All Rights Reserved
3
*
4
* Licensed under the Apache License, Version 2.0 (the "License");
5
* you may not use this file except in compliance with the License.
6
* You may obtain a copy of the License at
7
*
8
* http://www.apache.org/licenses/LICENSE-2.0
9
*
10
* Unless required by applicable law or agreed to in writing, software
11
* distributed under the License is distributed on an "AS IS" BASIS,
12
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
* See the License for the specific language governing permissions and
14
* limitations under the License.
15
*/
16
17
#ifndef __ONERT_BACKEND_TRAIN_OPS_DEPTHWISECONVOLUTIONLAYER_H__
18
#define __ONERT_BACKEND_TRAIN_OPS_DEPTHWISECONVOLUTIONLAYER_H__
19
20
#include <ops/DepthwiseConvolutionLayer.h>
21
#include <
backend/basic/Allocator.h
>
22
23
#include "../Tensor.h"
24
#include "../ExternalContext.h"
25
#include <
exec/train/ITrainableFunction.h
>
26
27
namespace
onert::backend::train::ops
28
{
29
30
class
DepthwiseConvolutionLayer
:
public
::onert::exec::train::ITrainableFunction
,
31
public
cpu::ops::DepthwiseConvolutionLayer
32
{
33
public
:
34
DepthwiseConvolutionLayer
();
35
36
void
configureBackward
(
IPortableTensor
*back_prop_input,
IPortableTensor
*grad_weights,
37
IPortableTensor
*grad_bias,
const
IPortableTensor
*back_prop_output,
38
const
ir::Activation
activation);
39
void
forward
(
bool
training)
override
;
40
void
backward
()
override
;
41
42
private
:
43
void
backwardFloat32();
44
45
private
:
46
IPortableTensor
*_grad_weights;
47
IPortableTensor
*_grad_bias;
48
IPortableTensor
*_back_prop_input;
49
const
IPortableTensor
*_back_prop_output;
50
51
// TODO Consider if these tensors should be built in TensorBuilder
52
std::unique_ptr<BackPropTensor> _act_back_prop_output;
53
std::unique_ptr<Tensor> _filter_dim_buffers;
54
};
30
class
DepthwiseConvolutionLayer
:
public
::onert::exec::train::ITrainableFunction
, {
…
};
55
56
}
// namespace onert::backend::train::ops
57
58
#endif
// __ONERT_BACKEND_TRAIN_OPS_DEPTHWISECONVOLUTIONLAYER_H__
ITrainableFunction.h
onert::backend::IPortableTensor
A tensor class that is portable for other backends.
Definition
IPortableTensor.h:37
onert::backend::cpu::ops::DepthwiseConvolutionLayer
Definition
DepthwiseConvolutionLayer.h:31
onert::backend::train::ops::DepthwiseConvolutionLayer
Definition
DepthwiseConvolutionLayer.h:32
onert::backend::train::ops::DepthwiseConvolutionLayer::configureBackward
void configureBackward(IPortableTensor *back_prop_input, IPortableTensor *grad_weights, IPortableTensor *grad_bias, const IPortableTensor *back_prop_output, const ir::Activation activation)
Definition
DepthwiseConvolutionLayer.cc:36
onert::backend::train::ops::DepthwiseConvolutionLayer::backward
void backward() override
Definition
DepthwiseConvolutionLayer.cc:90
onert::backend::train::ops::DepthwiseConvolutionLayer::forward
void forward(bool training) override
Definition
DepthwiseConvolutionLayer.cc:88
onert::backend::train::ops::DepthwiseConvolutionLayer::DepthwiseConvolutionLayer
DepthwiseConvolutionLayer()
Definition
DepthwiseConvolutionLayer.cc:28
onert::exec::train::ITrainableFunction
Definition
ITrainableFunction.h:29
onert::backend::train::ops
Definition
BackPropAccumulator.cc:25
onert::ir::Activation
Activation
Definition
InternalType.h:26
Allocator.h
runtime
onert
backend
train
ops
DepthwiseConvolutionLayer.h
Generated by
1.9.8