1 /* 2 * Copyright (c) 2023 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16 #ifndef NEURAL_NETWORK_RUNTIME_RANGE_BUILDER_H 17 #define NEURAL_NETWORK_RUNTIME_RANGE_BUILDER_H 18 19 #include "mindir.h" 20 21 #include "ops_builder.h" 22 #include "ops_registry.h" 23 24 namespace OHOS { 25 namespace NeuralNetworkRuntime { 26 namespace Ops { 27 class RangeBuilder : public OpsBuilder { 28 public: 29 typedef OH_NN_ReturnCode (RangeBuilder::*FuncPtr)(const std::shared_ptr<NNTensor>&); 30 31 RangeBuilder(); 32 ~RangeBuilder() override; 33 OH_NN_ReturnCode Build(const std::vector<uint32_t>& paramsIndex, 34 const std::vector<uint32_t>& inputsIndex, 35 const std::vector<uint32_t>& outputsIndex, 36 const std::vector<std::shared_ptr<NNTensor>>& allTensors) override; 37 38 LiteGraphPrimitvePtr GetPrimitive() override; 39 40 private: 41 OH_NN_ReturnCode SetStart(const std::shared_ptr<NNTensor>& tensor); 42 OH_NN_ReturnCode SetLimit(const std::shared_ptr<NNTensor>& tensor); 43 OH_NN_ReturnCode SetDelta(const std::shared_ptr<NNTensor>& tensor); 44 45 private: 46 int64_t m_start {0}; 47 int64_t m_limit {0}; 48 int64_t m_delta {1}; 49 std::unordered_map<OH_NN_TensorType, FuncPtr> m_paramMap = { 50 {OH_NN_RANGE_START, &RangeBuilder::SetStart}, 51 {OH_NN_RANGE_LIMIT, &RangeBuilder::SetLimit}, 52 {OH_NN_RANGE_DELTA, &RangeBuilder::SetDelta} 53 }; 54 }; 55 } // namespace Ops 56 } // namespace NeuralNetworkRuntime 57 } // namespace OHOS 58 59 #endif // NEURAL_NETWORK_RUNTIME_RANGE_BUILDER_H