\#include "stdafx.h"
|
\#include "pch.h"
|
\#include "${pyName}.h"
|
\#include <string>
|
\#include "pyutils.h"
|
\#include "jni.h"
|
\#include "Python.h"
|
\#include "PyGILThreadLock.h"
|
\#include "convertutils.h"
|
|
using namespace std;
|
|
jobject ${pyName}_train(JNIEnv* env, jobjectArray data_train, jobject settings)
|
{
|
try
|
{
|
PyGILThreadLock lock;
|
PyObject* pModule = create_py_module("${pyModule}.${pyName}");
|
if (pModule == NULL)
|
{
|
cout << "pModule error" << endl;
|
throw "模块调用失败!";
|
}
|
|
//*************导入函数******************
|
PyObject* pFunc = PyObject_GetAttrString(pModule, "train");
|
if (pFunc == NULL)
|
{
|
cout << "pfunc error" << endl;
|
throw "函数调用失败!";
|
}
|
PyObject* data_1 = ConvertJdarrToPydarr(env, data_train);
|
PyObject* settings_ = ConvertJhmapToPydict(env, settings);
|
|
//************构造参数数据 ********************
|
PyObject* pArg = PyTuple_New(2);
|
PyTuple_SetItem(pArg, 0, data_1);
|
PyTuple_SetItem(pArg, 1, settings_);
|
|
/*PyTuple_SetItem(pArg, 1, parseCppData(data_in->feature_range));*/
|
|
|
//********************调用python方法计算*****************
|
PyObject* pReturn = PyEval_CallObject(pFunc, pArg);
|
if (pReturn == NULL)
|
{
|
cout << "pReturn error" << endl;
|
throw "函数返回值异常!";
|
}
|
//*******************返回数据封装************************
|
// 开辟返回数据内存空间,转换数据,拆分数据
|
|
/*jobject result = jhmappydict_(env, pReturn);*/
|
jobject result = ConvertPydictToJhmap(env, pReturn);
|
if (result == NULL)
|
{
|
cout << "ConvertPydictToJhmap error" << endl;
|
throw "函数返回值异常!";
|
}
|
delete pModule, pFunc, data_1, settings_, pArg;
|
return result;
|
}
|
catch (const char* msg)
|
{
|
cout << "train error" << endl;
|
return NULL;
|
}
|
}
|
|
jobject ${pyName}_predict(JNIEnv* env, #{foreach} ($column in [1..$dataLength])jobjectArray data${column}, #{end}jobject model_path_,jobject settings)
|
{
|
try
|
{
|
|
PyGILThreadLock lock;
|
PyObject* pModule = create_py_module("${pyModule}.${pyName}");
|
if (pModule == NULL)
|
{
|
cout << "model error" << endl;
|
throw "模块调用失败!";
|
}
|
|
//*************导入函数******************
|
PyObject* pFunc = PyObject_GetAttrString(pModule, "predict");
|
if (pFunc == NULL)
|
{
|
cout << "func error" << endl;
|
throw "函数调用失败!";
|
}
|
#{foreach} ($column in [1..$dataLength])
|
PyObject* data_${column} = ConvertJdarrToPydarr(env, data${column});
|
#{end}
|
PyObject* model_path = ConvertJhmapToPydict(env, model_path_);
|
PyObject* settings_1 = ConvertJhmapToPydict(env, settings);
|
|
|
//************构造参数数据 ********************
|
#set($a=$dataLength + 2)
|
PyObject* pArg = PyTuple_New(${a});
|
#{foreach} ($column in [1..$dataLength])
|
#set($a=$column - 1)
|
PyTuple_SetItem(pArg, ${a}, data_${column});
|
#{end}
|
PyTuple_SetItem(pArg, ${dataLength}, model_path);
|
#set($a=$dataLength + 1)
|
PyTuple_SetItem(pArg, ${a}, settings_1);
|
|
/*PyTuple_SetItem(pArg, 1, parseCppData(data_in->feature_range));*/
|
|
|
//********************调用python方法计算*****************
|
PyObject* pReturn = PyEval_CallObject(pFunc, pArg);
|
if (pReturn == NULL)
|
{
|
cout << "return error" << endl;
|
throw "函数返回值异常!";
|
}
|
//*******************返回数据封装************************
|
// 开辟返回数据内存空间,转换数据,拆分数据
|
|
/*jobject result = jhmappydict_(env, pReturn);*/
|
jobject result = ConvertPydictToJhmap(env, pReturn);
|
if (result == NULL)
|
{
|
cout << "ConvertPydictToJhmap error" << endl;
|
throw "函数返回值异常!";
|
}
|
delete pModule;
|
pModule = nullptr;
|
delete pModule;
|
|
delete pFunc;
|
pFunc = nullptr;
|
delete pFunc;
|
|
#{foreach} ($column in [1..$dataLength])
|
delete[] data_${column};
|
data_${column} = nullptr;
|
delete data_${column};
|
|
#{end}
|
delete model_path;
|
model_path = nullptr;
|
delete model_path;
|
|
delete settings_1;
|
settings_1 = nullptr;
|
delete settings_1;
|
|
delete[] pArg;
|
pArg = nullptr;
|
delete pArg;
|
|
return result;
|
}
|
catch (const char* msg)
|
{
|
cout << "predict error" << endl;
|
return NULL;
|
}
|
}
|