ONE - On-device Neural Engine
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
ReshapeLayer.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 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#include "ReshapeLayer.h"
18
20{
21
22ReshapeLayer::ReshapeLayer() : _input(nullptr), _shape(nullptr), _output(nullptr)
23{
24 // DO NOTHING
25}
26
28{
29 // output buffer equals to input buffer means that copy is not needed
30 if (_output->buffer() != _input->buffer())
31 {
32 size_t count = _input->total_size();
33 memcpy(_output->buffer(), _input->buffer(), count);
34 }
35}
36
38 IPortableTensor *output)
39{
40 _input = input;
41 /* note : shape is optional. If not provided from model, _shape is nullptr. */
42 _shape = shape;
43 _output = output;
44}
45
47
48} // namespace onert::backend::cpu::ops
A tensor class that is portable for other backends.
size_t total_size() const override final
virtual uint8_t * buffer() const =0
void configure(const IPortableTensor *input, const IPortableTensor *shape, IPortableTensor *output)