\#include "stdafx.h"
|
\#include "pch.h"
|
\#include <string>
|
\#include "pyutils.h"
|
\#include "jni.h"
|
\#include "Python.h"
|
\#include "PyGILThreadLock.h"
|
\#include "convertutils.h"
|
|
using namespace std;
|
|
#{foreach} ($mpkEntity in $entities)
|
#{foreach} ($entity in $mpkEntity.modelMethods)
|
jobject ${mpkEntity.pyName}_${entity.methodName}(JNIEnv* env, #{foreach} ($column in [1..$entity.dataLength])jobjectArray data${column}, #{end}#{if}($entity.model==1)jobject model_path_, #{end}jobject settings)
|
{
|
try
|
{
|
|
PyGILThreadLock lock;
|
PyObject* pModule = create_py_module("${mpkEntity.pyModule}.${mpkEntity.pyName}");
|
if (pModule == NULL)
|
{
|
cout << "model error" << endl;
|
throw "模块调用失败!";
|
}
|
|
//*************导入函数******************
|
PyObject* pFunc = PyObject_GetAttrString(pModule, "${entity.methodName}");
|
if (pFunc == NULL)
|
{
|
cout << "func error" << endl;
|
throw "函数调用失败!";
|
}
|
#{foreach} ($column in [1..$entity.dataLength])
|
PyObject* data_${column} = ConvertJdarrToPydarr(env, data${column});
|
#{end}
|
#{if}($entity.model==1)
|
PyObject* model_path = ConvertJhmapToPydict(env, model_path_);
|
#{end}
|
PyObject* settings_1 = ConvertJhmapToPydict(env, settings);
|
|
|
//************构造参数数据 ********************
|
#{if}($entity.model==1)
|
#set($a=$entity.dataLength + 2)
|
PyObject* pArg = PyTuple_New(${a});
|
#{else}
|
#set($a=$entity.dataLength + 1)
|
PyObject* pArg = PyTuple_New(${a});
|
#{end}
|
#{foreach} ($column in [1..$entity.dataLength])
|
#set($a=$column - 1)
|
PyTuple_SetItem(pArg, ${a}, data_${column});
|
#{end}
|
#{if}($entity.model==1)
|
PyTuple_SetItem(pArg, ${entity.dataLength}, model_path);
|
#set($a=$entity.dataLength + 1)
|
PyTuple_SetItem(pArg, ${a}, settings_1);
|
#{else}
|
PyTuple_SetItem(pArg, ${entity.dataLength}, settings_1);
|
#{end}
|
|
/*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..$entity.dataLength])
|
delete[] data_${column};
|
data_${column} = nullptr;
|
delete data_${column};
|
|
#{end}
|
#{if}($entity.model==1)
|
delete model_path;
|
model_path = nullptr;
|
delete model_path;
|
#{end}
|
|
delete settings_1;
|
settings_1 = nullptr;
|
delete settings_1;
|
|
delete[] pArg;
|
pArg = nullptr;
|
delete pArg;
|
|
return result;
|
}
|
catch (const char* msg)
|
{
|
cout << "${entity.methodName} error" << endl;
|
return NULL;
|
}
|
}
|
|
#{end}
|
|
#{end}
|