generated from zhangwei/Matrixai
251 lines
7.9 KiB
C++
251 lines
7.9 KiB
C++
/**
|
|
* engine管理实现
|
|
* */
|
|
|
|
#include "EngineManager.h"
|
|
#include "Config.h"
|
|
#include "TimeUtil.h"
|
|
#include <curl/curl.h>
|
|
|
|
namespace ai_matrix
|
|
{
|
|
EngineManager::EngineManager() {}
|
|
|
|
EngineManager::~EngineManager() {}
|
|
|
|
//初始化acl
|
|
APP_ERROR EngineManager::Init()
|
|
{
|
|
if (!InitDeviceIds())
|
|
{
|
|
LogError << "InitDeviceIds err";
|
|
return APP_ERR_COMM_INVALID_PARAM;
|
|
}
|
|
|
|
return APP_ERR_OK;
|
|
}
|
|
|
|
//去初始化acl
|
|
APP_ERROR EngineManager::DeInit(void)
|
|
{
|
|
return APP_ERR_OK;
|
|
}
|
|
|
|
//加载yaml文件中的配置
|
|
APP_ERROR EngineManager::load_yaml_config(std::string path)
|
|
{
|
|
try
|
|
{
|
|
YAML::Node config = YAML::LoadFile(path);
|
|
//退出程序
|
|
if (config.IsNull())
|
|
{
|
|
LogError << "matrix.yaml err";
|
|
return APP_ERR_COMM_INVALID_PARAM;
|
|
}
|
|
|
|
//engine使用deviceid
|
|
mapUseDevice_["ALL"] = *init_deviceIds_.begin(); //默认所有engine使用初始化中最小deviceid
|
|
if(config["use_deviceid"].IsDefined())
|
|
{
|
|
for (YAML::const_iterator it = config["use_deviceid"].begin(); it != config["use_deviceid"].end(); it++)
|
|
{
|
|
std::string engineInfo = it->first.as<std::string>();
|
|
int deviceid = it->second.as<int>();
|
|
//使用deviceid必须是经过初始化的
|
|
if (init_deviceIds_.count(deviceid) == 0)
|
|
{
|
|
LogError << "use_deviceid set err value:" << deviceid;
|
|
return APP_ERR_COMM_INVALID_PARAM;
|
|
}
|
|
mapUseDevice_[engineInfo] = deviceid;
|
|
}
|
|
}
|
|
|
|
//engine实例
|
|
for (YAML::const_iterator it = config["engines"].begin(); it != config["engines"].end(); it++)
|
|
{
|
|
std::string engine_name = it->first.as<std::string>();
|
|
int engine_id = it->second.as<int>();
|
|
|
|
//检查是否有重复engine
|
|
std::string engine_unique = engine_name + "_" + std::to_string(engine_id);
|
|
auto iter = engine_map_.find(engine_unique);
|
|
if (iter != engine_map_.end())
|
|
{
|
|
continue;
|
|
}
|
|
|
|
//实例化engine
|
|
std::shared_ptr<EngineBase> engineInstance = nullptr;
|
|
EngineBase* base = (static_cast<EngineBase*>(EngineFactory::MakeEngine(engine_name)));
|
|
if (base == nullptr)
|
|
{
|
|
continue;
|
|
}
|
|
engineInstance.reset(base);
|
|
|
|
//初始化engine
|
|
APP_ERROR ret = InitEngineInstance(engineInstance, engine_name, engine_id);
|
|
if (ret != APP_ERR_OK)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
//存入map
|
|
engine_map_[engine_unique] = engineInstance;
|
|
}
|
|
|
|
//engine连接
|
|
for (YAML::const_iterator it = config["connects"].begin(); it != config["connects"].end(); it++)
|
|
{
|
|
std::string from = it->first.as<std::string>();
|
|
std::string to = it->second.as<std::string>();
|
|
|
|
int iPos = to.find(" ");
|
|
int iQueueSize = 0;
|
|
if (iPos != std::string::npos)
|
|
{
|
|
iQueueSize = atoi(to.substr(iPos+1, to.length()).c_str());
|
|
to = to.substr(0, iPos);
|
|
// LogInfo << "iQueueSize:" << iQueueSize;
|
|
}
|
|
|
|
LogInfo << "Add Connect,send:" << from << ",to:" << to;
|
|
|
|
std::size_t pos = from.find_last_of("_");
|
|
if (pos == std::string::npos)
|
|
{
|
|
continue;
|
|
}
|
|
std::string src_engine = from.substr(0, pos);
|
|
|
|
pos = to.find_last_of("_");
|
|
if (pos == std::string::npos)
|
|
{
|
|
continue;
|
|
}
|
|
std::string dst_engine = to.substr(0, pos);
|
|
|
|
auto iterSend = engine_map_.find(src_engine);
|
|
auto iterRecv = engine_map_.find(dst_engine);
|
|
|
|
if (iterSend == engine_map_.end() || iterRecv == engine_map_.end())
|
|
{
|
|
LogError << "Cann't find engine " << src_engine << " or " << dst_engine;
|
|
continue;
|
|
}
|
|
|
|
std::shared_ptr<MyQueue<std::shared_ptr<void>>> dataQueue = iterRecv->second->GetInputMap(to);
|
|
if (dataQueue == nullptr)
|
|
{
|
|
dataQueue = std::make_shared<MyQueue<std::shared_ptr<void>>>();
|
|
if (iQueueSize > 0)
|
|
{
|
|
dataQueue->setMaxSize(iQueueSize);
|
|
}
|
|
|
|
//设置engine输入队列
|
|
iterRecv->second->SetInputMap(to, dataQueue);
|
|
|
|
//设置engine输出队列
|
|
iterSend->second->SetOutputMap(from, dataQueue);
|
|
}
|
|
else
|
|
{
|
|
//设置engine输出队列
|
|
iterSend->second->SetOutputMap(from, dataQueue);
|
|
}
|
|
}
|
|
}
|
|
catch (...) //捕获所有异常
|
|
{
|
|
return APP_ERR_COMM_INVALID_PARAM;
|
|
}
|
|
return APP_ERR_OK;
|
|
}
|
|
|
|
//初始化engine实例
|
|
APP_ERROR EngineManager::InitEngineInstance(std::shared_ptr<EngineBase> engineInstance, std::string engineName, int engineId)
|
|
{
|
|
LogInfo << "EngineManager: begin to init engine instance,name=" << engineName << ", engine id = " << engineId << ".";
|
|
|
|
//获取egnine使用的上下文
|
|
std::string engineInfo = engineName + "_" + std::to_string(engineId);
|
|
int deviceid;
|
|
if(mapUseDevice_.count(engineInfo) > 0)
|
|
{
|
|
deviceid = mapUseDevice_[engineInfo];
|
|
}
|
|
else if(mapUseDevice_.count(std::to_string(engineId)) > 0)
|
|
{
|
|
deviceid = mapUseDevice_[std::to_string(engineId)];
|
|
}
|
|
else
|
|
{
|
|
deviceid = mapUseDevice_["ALL"];
|
|
}
|
|
|
|
EngineInitArguments initArgs;
|
|
initArgs.deviceId = deviceId_;
|
|
initArgs.engineName = engineName;
|
|
initArgs.engineId = engineId;
|
|
|
|
engineInstance->AssignInitArgs(initArgs); //填充参数
|
|
|
|
APP_ERROR ret = engineInstance->Init(); //执行初始化
|
|
if (ret != APP_ERR_OK)
|
|
{
|
|
LogError << "EngineManager: fail to init engine, name = " << engineName << ", engine id = " << engineId << ".";
|
|
return ret;
|
|
}
|
|
LogInfo << "EngineManager: engine " << engineName << "[" << engineId << "] init success.";
|
|
return ret;
|
|
}
|
|
|
|
//运行所有engine
|
|
APP_ERROR EngineManager::RunAllEngine()
|
|
{
|
|
LogInfo << "begin to run engine.";
|
|
for (auto it = engine_map_.begin(); it != engine_map_.end(); it++)
|
|
{
|
|
it->second->Run();
|
|
}
|
|
return APP_ERR_OK;
|
|
}
|
|
|
|
//停止所有engine
|
|
APP_ERROR EngineManager::StopAllEngine()
|
|
{
|
|
LogInfo << "begin to stop engine.";
|
|
for (auto it = engine_map_.begin(); it != engine_map_.end(); it++)
|
|
{
|
|
it->second->Stop();
|
|
}
|
|
return APP_ERR_OK;
|
|
}
|
|
|
|
//得到engine指针
|
|
EngineBase *EngineManager::get_engine(std::string engineName)
|
|
{
|
|
auto iter = engine_map_.find(engineName);
|
|
if (iter == engine_map_.end())
|
|
{
|
|
return nullptr;
|
|
}
|
|
return iter->second.get();
|
|
}
|
|
|
|
/**
|
|
* 初始化设备id
|
|
* inParam : N/A
|
|
* outParam: N/A
|
|
* return : true(成功);false(失败)
|
|
*/
|
|
bool EngineManager::InitDeviceIds()
|
|
{
|
|
init_deviceIds_.insert(0);
|
|
return true;
|
|
}
|
|
}
|