1 /* 2 * Copyright (c) 2024 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_CROP_BUILDER_H 17 #define NEURAL_NETWORK_RUNTIME_CROP_BUILDER_H 18 19 #include "ops_builder.h" 20 21 namespace OHOS { 22 namespace NeuralNetworkRuntime { 23 namespace Ops { 24 class CropBuilder : public OpsBuilder { 25 public: 26 typedef OH_NN_ReturnCode (CropBuilder::*FuncPtr)(const std::shared_ptr<NNTensor>&); 27 28 CropBuilder(); 29 ~CropBuilder() override; 30 OH_NN_ReturnCode Build(const std::vector<uint32_t>& paramsIndex, 31 const std::vector<uint32_t>& inputsIndex, 32 const std::vector<uint32_t>& outputsIndex, 33 const std::vector<std::shared_ptr<NNTensor>>& allTensors) override; 34 35 LiteGraphPrimitvePtr GetPrimitive() override; 36 37 private: 38 OH_NN_ReturnCode SetAxis(const std::shared_ptr<NNTensor>& tensor); 39 OH_NN_ReturnCode SetOffset(const std::shared_ptr<NNTensor>& tensor); 40 41 private: 42 int64_t m_axis {0}; 43 std::vector<int64_t> m_offset; 44 std::unordered_map<OH_NN_TensorType, FuncPtr> m_paramMap = { 45 {OH_NN_CROP_AXIS, &CropBuilder::SetAxis}, 46 {OH_NN_CROP_OFFSET, &CropBuilder::SetOffset} 47 }; 48 }; 49 } // namespace Ops 50 } // namespace NeuralNetworkRuntime 51 } // namespace OHOS 52 53 #endif // NEURAL_NETWORK_RUNTIME_CROP_BUILDER_H