You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
graphengine/ge/ge_runtime/model_runner.cc

174 lines
5.4 KiB

/**
* Copyright 2019-2020 Huawei Technologies Co., Ltd
*
* 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 "ge_runtime/model_runner.h"
#include "./runtime_model.h"
#include "framework/common/debug/ge_log.h"
#include "common/ge_inner_error_codes.h"
#include "common/ge/ge_util.h"
#include "ge_runtime/davinci_model.h"
#include "graph/op_desc.h"
namespace ge {
namespace model_runner {
using RuntimeModelPtr = std::shared_ptr<RuntimeModel>;
using DavinciModelPtr = std::shared_ptr<DavinciModel>;
ModelRunner &ModelRunner::Instance() {
static ModelRunner instance; // Guaranteed to be destroyed.
return instance;
}
bool ModelRunner::LoadDavinciModel(uint32_t device_id, uint64_t session_id, uint32_t model_id,
std::shared_ptr<DavinciModel> davinci_model,
std::shared_ptr<ModelListener> listener) {
std::shared_ptr<RuntimeModel> model = MakeShared<RuntimeModel>();
if (model == nullptr) {
return false;
}
bool status = model->Load(device_id, session_id, davinci_model);
if (!status) {
return false;
}
runtime_models_[model_id] = model;
return true;
}
bool ModelRunner::DistributeTask(uint32_t model_id) {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
return false;
}
return model_iter->second->DistributeTask();
}
bool ModelRunner::LoadModelComplete(uint32_t model_id) {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
return false;
}
return model_iter->second->LoadComplete();
}
const std::vector<uint32_t> &ModelRunner::GetTaskIdList(uint32_t model_id) const {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
static const std::vector<uint32_t> empty_ret;
return empty_ret;
}
return model_iter->second->GetTaskIdList();
}
const std::vector<uint32_t> &ModelRunner::GetStreamIdList(uint32_t model_id) const {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
static const std::vector<uint32_t> empty_ret;
return empty_ret;
}
return model_iter->second->GetStreamIdList();
}
const std::map<std::string, std::shared_ptr<RuntimeInfo>> &ModelRunner::GetRuntimeInfoMap(uint32_t model_id) const {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGW("Model id %u not found.", model_id);
static const std::map<std::string, std::shared_ptr<RuntimeInfo>> empty_ret;
return empty_ret;
}
return model_iter->second->GetRuntimeInfoMap();
}
void *ModelRunner::GetModelHandle(uint32_t model_id) const {
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGW("Model id %u not found.", model_id);
return nullptr;
}
return model_iter->second->GetModelHandle();
}
bool ModelRunner::UnloadModel(uint32_t model_id) {
auto iter = runtime_models_.find(model_id);
if (iter != runtime_models_.end()) {
(void)runtime_models_.erase(iter);
return true;
}
return false;
}
bool ModelRunner::RunModel(uint32_t model_id, const InputData &input_data, OutputData *output_data) {
if (output_data == nullptr) {
GELOGW("Output data point is null.");
}
auto model_iter = runtime_models_.find(model_id);
if (model_iter == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
return false;
}
bool status = model_iter->second->CopyInputData(input_data);
if (!status) {
GELOGE(FAILED, "Copy input data fail.");
return false;
}
status = model_iter->second->Run();
if (!status) {
GELOGE(FAILED, "Run model fail.");
return false;
}
return true;
}
bool ModelRunner::GetInputOutputDescInfo(uint32_t model_id, bool zero_copy,
std::vector<InputOutputDescInfo> *input_desc,
std::vector<InputOutputDescInfo> *output_desc,
std::vector<uint32_t> *input_format, std::vector<uint32_t> *output_format) {
if (runtime_models_.find(model_id) == runtime_models_.end()) {
GELOGE(PARAM_INVALID, "Model id %u not found.", model_id);
return false;
}
auto model = runtime_models_[model_id];
if (input_desc == nullptr || output_desc == nullptr) {
GELOGE(PARAM_INVALID, "input_desc or output_desc is null.");
return false;
}
bool status = model->GetInputOutputDescInfo(zero_copy, input_desc, output_desc, input_format, output_format);
if (!status) {
GELOGE(FAILED, "Get input output desc info fail.");
return false;
}
return true;
}
} // namespace model_runner
} // namespace ge