diff options
Diffstat (limited to 'runtime/neurun/backend/srcn/TensorBuilder.cc')
-rw-r--r-- | runtime/neurun/backend/srcn/TensorBuilder.cc | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/runtime/neurun/backend/srcn/TensorBuilder.cc b/runtime/neurun/backend/srcn/TensorBuilder.cc new file mode 100644 index 000000000..5ac25c33e --- /dev/null +++ b/runtime/neurun/backend/srcn/TensorBuilder.cc @@ -0,0 +1,107 @@ +/* + * Copyright (c) 2019 Samsung Electronics Co., Ltd. All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "TensorBuilder.h" + +#include <cassert> +#include "Convert.h" +#include "util/logging.h" + +namespace neurun +{ +namespace backend +{ +namespace srcn +{ + +TensorBuilder::TensorBuilder() : _tensor_mgr{new TensorManager()} +{ + // DO NOTHING +} + +void TensorBuilder::registerTensorInfo(const ir::OperandIndex &ind, + const ir::OperandInfo &tensor_info, + ir::Layout backend_layout, bool as_const) +{ + _tensor_info_map.emplace(ind, tensor_info); + _tensor_layout_map.emplace(ind, backend_layout); + + if (as_const) + _constants.append(ind); +} + +void TensorBuilder::registerSubTensorInfo(const ir::OperandIndex &, const compiler::SubTensorInfo &) +{ + // Not supported yet + assert(false); +} + +void TensorBuilder::notifyFirstUse(const ir::OperandIndex &ind) +{ + assert(_tensor_info_map.find(ind) != _tensor_info_map.end()); + const auto &tensor_info = _tensor_info_map.at(ind); + const auto size = tensor_info.total_size(); + const auto &backend_layout = _tensor_layout_map.at(ind); + _tensor_mgr->buildTensor(ind, tensor_info, backend_layout, _constants.contains(ind)); + _tensor_mgr->claimPlan(ind, size); +} + +void TensorBuilder::notifyLastUse(const ir::OperandIndex &ind) { _tensor_mgr->releasePlan(ind); } + +bool TensorBuilder::isRegistered(const ir::OperandIndex &ind) const +{ + return _tensor_info_map.find(ind) != _tensor_info_map.end(); +} + +void TensorBuilder::prepare(void) +{ + _tensor_mgr->allocateConsts(); + _tensor_mgr->allocateNonconsts(); +} + +void TensorBuilder::allocateConsts() +{ + // NOTE For now nothing to do. Allocation is done in prepare stage, which is not appropriate + // This is because SRCN kernels require `ITensor`s to be allocated before Kernel Generation. +} + +void TensorBuilder::allocateNonconsts() +{ + // NOTE For now nothing to do. Allocation is done in prepare stage, which is not appropriate + // This is because SRCN kernels require `ITensor`s to be allocated before Kernel Generation. +} + +std::shared_ptr<::neurun::backend::operand::ITensor> +TensorBuilder::tensorAt(const ir::OperandIndex &ind) +{ + return _tensor_mgr->at(ind); +} + +void TensorBuilder::iterate(const IterateFunction &fn) { _tensor_mgr->iterate(fn); } + +std::shared_ptr<operand::Tensor> TensorBuilder::at(const ir::OperandIndex &ind) +{ + return _tensor_mgr->at(ind); +} + +std::unique_ptr<ITensorManager> TensorBuilder::releaseTensorManager(void) +{ + return std::move(_tensor_mgr); +} + +} // namespace srcn +} // namespace backend +} // namespace neurun |