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
ConvolutionLayer.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2023 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_CONVOLUTIONLAYER_H__
18
#define __ONERT_BACKEND_TRAIN_OPS_CONVOLUTIONLAYER_H__
19
20
#include <ops/ConvolutionLayer.h>
21
22
#include "../Tensor.h"
23
#include <
exec/train/ITrainableFunction.h
>
24
25
namespace
onert::backend::train::ops
26
{
27
28
class
ConvolutionLayer
:
public
::onert::exec::train::ITrainableFunction
,
29
public
cpu::ops::ConvolutionLayer
30
{
31
public
:
32
ConvolutionLayer
();
33
~ConvolutionLayer
();
34
35
void
configureBackward
(
const
IPortableTensor
*weights,
IPortableTensor
*back_prop_input,
36
IPortableTensor
*grad_weights,
IPortableTensor
*grad_bias,
37
const
IPortableTensor
*back_prop_output,
const
ir::Activation
activation);
38
void
forward
(
bool
training)
override
;
39
void
backward
()
override
;
40
41
private
:
42
void
backwardFloat32();
43
44
private
:
45
IPortableTensor
*_grad_weights;
46
IPortableTensor
*_grad_bias;
47
IPortableTensor
*_back_prop_input;
48
const
IPortableTensor
*_back_prop_output;
49
50
// TODO Consider if these tensors should be built in TensorBuilder
51
std::unique_ptr<Tensor> _transposed_weights;
52
std::unique_ptr<BackPropTensor> _conv_back_prop_output;
53
std::unique_ptr<BackPropTensor> _act_back_prop_output;
54
std::unique_ptr<GradientTensor> _transposed_grad_weights;
55
};
28
class
ConvolutionLayer
:
public
::onert::exec::train::ITrainableFunction
, {
…
};
56
57
}
// namespace onert::backend::train::ops
58
59
#endif
// __ONERT_BACKEND_TRAIN_OPS_CONVOLUTIONLAYER_H__
ITrainableFunction.h
onert::backend::IPortableTensor
A tensor class that is portable for other backends.
Definition
IPortableTensor.h:37
onert::backend::cpu::ops::ConvolutionLayer
Definition
ConvolutionLayer.h:38
onert::backend::train::ops::ConvolutionLayer
Definition
ConvolutionLayer.h:30
onert::backend::train::ops::ConvolutionLayer::ConvolutionLayer
ConvolutionLayer()
Definition
ConvolutionLayer.cc:53
onert::backend::train::ops::ConvolutionLayer::backward
void backward() override
Definition
ConvolutionLayer.cc:98
onert::backend::train::ops::ConvolutionLayer::forward
void forward(bool training) override
Definition
ConvolutionLayer.cc:97
onert::backend::train::ops::ConvolutionLayer::configureBackward
void configureBackward(const IPortableTensor *weights, IPortableTensor *back_prop_input, IPortableTensor *grad_weights, IPortableTensor *grad_bias, const IPortableTensor *back_prop_output, const ir::Activation activation)
Definition
ConvolutionLayer.cc:62
onert::backend::train::ops::ConvolutionLayer::~ConvolutionLayer
~ConvolutionLayer()
onert::exec::train::ITrainableFunction
Definition
ITrainableFunction.h:29
onert::backend::train::ops
Definition
BackPropAccumulator.cc:25
onert::ir::Activation
Activation
Definition
InternalType.h:26
runtime
onert
backend
train
ops
ConvolutionLayer.h
Generated by
1.9.8