ONE - On-device Neural Engine
Loading...
Searching...
No Matches
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
19namespace onert
20{
21namespace backend
22{
23namespace cpu
24{
25namespace ops
26{
27
28ReshapeLayer::ReshapeLayer() : _input(nullptr), _shape(nullptr), _output(nullptr)
29{
30 // DO NOTHING
31}
32
34{
35 // output buffer equals to input buffer means that copy is not needed
36 if (_output->buffer() != _input->buffer())
37 {
38 size_t count = _input->total_size();
39 memcpy(_output->buffer(), _input->buffer(), count);
40 }
41}
42
44 IPortableTensor *output)
45{
46 _input = input;
47 /* note : shape is optional. If not provided from model, _shape is nullptr. */
48 _shape = shape;
49 _output = output;
50}
51
53
54} // namespace ops
55} // namespace cpu
56} // namespace backend
57} // namespace onert
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)