1e24cf92b4636738f47ada2aaa6f1806af6aa0b3
[platform/core/ml/nnfw.git] / runtime / onert / core / src / compiler / Linear.h
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 #ifndef __ONERT_COMPILER_LINEAR_H__
18 #define __ONERT_COMPILER_LINEAR_H__
19
20 #include <vector>
21 #include <memory>
22
23 #include "ir/OpSequences.h"
24 #include "ir/Index.h"
25 #include "backend/ITensorBuilder.h"
26 #include "compiler/LoweredGraph.h"
27
28 namespace onert
29 {
30 namespace ir
31 {
32 struct OperationVisitor;
33 } // namespace ir
34 } // namespace onert
35
36 namespace onert
37 {
38 namespace compiler
39 {
40
41 class Linear
42 {
43 public:
44   static std::vector<ir::OpSequenceIndex> linearize(const compiler::LoweredGraph &lowered_graph);
45   static void dump(const compiler::LoweredGraph &lowered_graph,
46                    const std::vector<ir::OpSequenceIndex> &order);
47   static void planTensors(const compiler::LoweredGraph &lowered_graph,
48                           const std::vector<ir::OpSequenceIndex> &order);
49 };
50
51 } // namespace compiler
52 } // namespace onert
53
54 #endif // __ONERT_COMPILER_LINEAR_H__