You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

lite_session.cpp 21 kB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. /**
  2. * Copyright 2020 Huawei Technologies Co., Ltd
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include <jni.h>
  17. #include <fstream>
  18. #include "common/ms_log.h"
  19. #include "include/lite_session.h"
  20. #include "include/errorcode.h"
  21. extern "C" JNIEXPORT jlong JNICALL Java_com_mindspore_lite_LiteSession_createSessionWithModel(JNIEnv *env, jobject thiz,
  22. jobject model_buffer,
  23. jlong ms_config_ptr) {
  24. // decode model buffer and buffer size
  25. if (model_buffer == nullptr) {
  26. MS_LOGE("Buffer from java is nullptr");
  27. return reinterpret_cast<jlong>(nullptr);
  28. }
  29. jlong buffer_len = env->GetDirectBufferCapacity(model_buffer);
  30. auto *model_buf = static_cast<char *>(env->GetDirectBufferAddress(model_buffer));
  31. // decode ms context
  32. auto *pointer = reinterpret_cast<void *>(ms_config_ptr);
  33. if (pointer == nullptr) {
  34. MS_LOGE("Context pointer from java is nullptr");
  35. return jlong(nullptr);
  36. }
  37. auto *lite_context_ptr = static_cast<mindspore::lite::Context *>(pointer);
  38. // create session
  39. auto session = mindspore::session::LiteSession::CreateSession(model_buf, buffer_len, lite_context_ptr);
  40. if (session == nullptr) {
  41. MS_LOGE("CreateSession failed");
  42. return jlong(nullptr);
  43. }
  44. return jlong(session);
  45. }
  46. extern "C" JNIEXPORT jlong JNICALL Java_com_mindspore_lite_LiteSession_createSession(JNIEnv *env, jobject thiz,
  47. jlong ms_config_ptr) {
  48. auto *pointer = reinterpret_cast<void *>(ms_config_ptr);
  49. if (pointer == nullptr) {
  50. MS_LOGE("Context pointer from java is nullptr");
  51. return jlong(nullptr);
  52. }
  53. auto *lite_context_ptr = static_cast<mindspore::lite::Context *>(pointer);
  54. auto session = mindspore::session::LiteSession::CreateSession(lite_context_ptr);
  55. if (session == nullptr) {
  56. MS_LOGE("CreateSession failed");
  57. return jlong(nullptr);
  58. }
  59. return jlong(session);
  60. }
  61. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_compileGraph(JNIEnv *env, jobject thiz,
  62. jlong session_ptr,
  63. jlong model_ptr) {
  64. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  65. if (session_pointer == nullptr) {
  66. MS_LOGE("Session pointer from java is nullptr");
  67. return (jboolean) false;
  68. }
  69. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  70. auto *model_pointer = reinterpret_cast<void *>(model_ptr);
  71. if (model_pointer == nullptr) {
  72. MS_LOGE("Model pointer from java is nullptr");
  73. return (jboolean) false;
  74. }
  75. auto *lite_model_ptr = static_cast<mindspore::lite::Model *>(model_pointer);
  76. auto ret = lite_session_ptr->CompileGraph(lite_model_ptr);
  77. return (jboolean)(ret == mindspore::lite::RET_OK);
  78. }
  79. extern "C" JNIEXPORT void JNICALL Java_com_mindspore_lite_LiteSession_bindThread(JNIEnv *env, jobject thiz,
  80. jlong session_ptr, jboolean if_bind) {
  81. auto *pointer = reinterpret_cast<void *>(session_ptr);
  82. if (pointer == nullptr) {
  83. MS_LOGE("Session pointer from java is nullptr");
  84. return;
  85. }
  86. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  87. lite_session_ptr->BindThread(if_bind);
  88. }
  89. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_runGraph(JNIEnv *env, jobject thiz,
  90. jlong session_ptr) {
  91. auto *pointer = reinterpret_cast<void *>(session_ptr);
  92. if (pointer == nullptr) {
  93. MS_LOGE("Session pointer from java is nullptr");
  94. return (jboolean) false;
  95. }
  96. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  97. auto ret = lite_session_ptr->RunGraph();
  98. return (jboolean)(ret == mindspore::lite::RET_OK);
  99. }
  100. extern "C" JNIEXPORT jobject JNICALL Java_com_mindspore_lite_LiteSession_getInputs(JNIEnv *env, jobject thiz,
  101. jlong session_ptr) {
  102. jclass array_list = env->FindClass("java/util/ArrayList");
  103. jmethodID array_list_construct = env->GetMethodID(array_list, "<init>", "()V");
  104. jobject ret = env->NewObject(array_list, array_list_construct);
  105. jmethodID array_list_add = env->GetMethodID(array_list, "add", "(Ljava/lang/Object;)Z");
  106. jclass long_object = env->FindClass("java/lang/Long");
  107. jmethodID long_object_construct = env->GetMethodID(long_object, "<init>", "(J)V");
  108. auto *pointer = reinterpret_cast<void *>(session_ptr);
  109. if (pointer == nullptr) {
  110. MS_LOGE("Session pointer from java is nullptr");
  111. return ret;
  112. }
  113. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  114. auto inputs = lite_session_ptr->GetInputs();
  115. for (auto input : inputs) {
  116. jobject tensor_addr = env->NewObject(long_object, long_object_construct, jlong(input));
  117. env->CallBooleanMethod(ret, array_list_add, tensor_addr);
  118. }
  119. return ret;
  120. }
  121. extern "C" JNIEXPORT jlong JNICALL Java_com_mindspore_lite_LiteSession_getInputsByTensorName(JNIEnv *env, jobject thiz,
  122. jlong session_ptr,
  123. jstring tensor_name) {
  124. auto *pointer = reinterpret_cast<void *>(session_ptr);
  125. if (pointer == nullptr) {
  126. MS_LOGE("Session pointer from java is nullptr");
  127. return jlong(nullptr);
  128. }
  129. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  130. auto input = lite_session_ptr->GetInputsByTensorName(env->GetStringUTFChars(tensor_name, JNI_FALSE));
  131. return jlong(input);
  132. }
  133. extern "C" JNIEXPORT jobject JNICALL Java_com_mindspore_lite_LiteSession_getOutputsByNodeName(JNIEnv *env, jobject thiz,
  134. jlong session_ptr,
  135. jstring node_name) {
  136. jclass array_list = env->FindClass("java/util/ArrayList");
  137. jmethodID array_list_construct = env->GetMethodID(array_list, "<init>", "()V");
  138. jobject ret = env->NewObject(array_list, array_list_construct);
  139. jmethodID array_list_add = env->GetMethodID(array_list, "add", "(Ljava/lang/Object;)Z");
  140. jclass long_object = env->FindClass("java/lang/Long");
  141. jmethodID long_object_construct = env->GetMethodID(long_object, "<init>", "(J)V");
  142. auto *pointer = reinterpret_cast<void *>(session_ptr);
  143. if (pointer == nullptr) {
  144. MS_LOGE("Session pointer from java is nullptr");
  145. return ret;
  146. }
  147. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  148. auto inputs = lite_session_ptr->GetOutputsByNodeName(env->GetStringUTFChars(node_name, JNI_FALSE));
  149. for (auto input : inputs) {
  150. jobject tensor_addr = env->NewObject(long_object, long_object_construct, jlong(input));
  151. env->CallBooleanMethod(ret, array_list_add, tensor_addr);
  152. env->DeleteLocalRef(tensor_addr);
  153. }
  154. return ret;
  155. }
  156. extern "C" JNIEXPORT jobject JNICALL Java_com_mindspore_lite_LiteSession_getOutputMapByTensor(JNIEnv *env, jobject thiz,
  157. jlong session_ptr) {
  158. jclass hash_map_clazz = env->FindClass("java/util/HashMap");
  159. jmethodID hash_map_construct = env->GetMethodID(hash_map_clazz, "<init>", "()V");
  160. jobject hash_map = env->NewObject(hash_map_clazz, hash_map_construct);
  161. jmethodID hash_map_put =
  162. env->GetMethodID(hash_map_clazz, "put", "(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;");
  163. auto *pointer = reinterpret_cast<void *>(session_ptr);
  164. if (pointer == nullptr) {
  165. MS_LOGE("Session pointer from java is nullptr");
  166. return hash_map;
  167. }
  168. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  169. auto outputs = lite_session_ptr->GetOutputs();
  170. jclass long_object = env->FindClass("java/lang/Long");
  171. jmethodID long_object_construct = env->GetMethodID(long_object, "<init>", "(J)V");
  172. for (const auto &output_iter : outputs) {
  173. auto node_name = output_iter.first;
  174. auto ms_tensor = output_iter.second;
  175. jobject tensor_addr = env->NewObject(long_object, long_object_construct, jlong(ms_tensor));
  176. env->CallObjectMethod(hash_map, hash_map_put, env->NewStringUTF(node_name.c_str()), tensor_addr);
  177. env->DeleteLocalRef(tensor_addr);
  178. }
  179. return hash_map;
  180. }
  181. extern "C" JNIEXPORT jobject JNICALL Java_com_mindspore_lite_LiteSession_getOutputTensorNames(JNIEnv *env, jobject thiz,
  182. jlong session_ptr) {
  183. jclass array_list = env->FindClass("java/util/ArrayList");
  184. jmethodID array_list_construct = env->GetMethodID(array_list, "<init>", "()V");
  185. jobject ret = env->NewObject(array_list, array_list_construct);
  186. jmethodID array_list_add = env->GetMethodID(array_list, "add", "(Ljava/lang/Object;)Z");
  187. auto *pointer = reinterpret_cast<void *>(session_ptr);
  188. if (pointer == nullptr) {
  189. MS_LOGE("Session pointer from java is nullptr");
  190. return ret;
  191. }
  192. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  193. auto output_names = lite_session_ptr->GetOutputTensorNames();
  194. for (const auto &output_name : output_names) {
  195. env->CallBooleanMethod(ret, array_list_add, env->NewStringUTF(output_name.c_str()));
  196. }
  197. return ret;
  198. }
  199. extern "C" JNIEXPORT jlong JNICALL Java_com_mindspore_lite_LiteSession_getOutputByTensorName(JNIEnv *env, jobject thiz,
  200. jlong session_ptr,
  201. jstring tensor_name) {
  202. auto *pointer = reinterpret_cast<void *>(session_ptr);
  203. if (pointer == nullptr) {
  204. MS_LOGE("Session pointer from java is nullptr");
  205. return jlong(nullptr);
  206. }
  207. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  208. auto output = lite_session_ptr->GetOutputByTensorName(env->GetStringUTFChars(tensor_name, JNI_FALSE));
  209. return jlong(output);
  210. }
  211. extern "C" JNIEXPORT void JNICALL Java_com_mindspore_lite_LiteSession_free(JNIEnv *env, jobject thiz,
  212. jlong session_ptr) {
  213. auto *pointer = reinterpret_cast<void *>(session_ptr);
  214. if (pointer == nullptr) {
  215. MS_LOGE("Session pointer from java is nullptr");
  216. return;
  217. }
  218. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  219. delete (lite_session_ptr);
  220. }
  221. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_resize(JNIEnv *env, jobject thiz,
  222. jlong session_ptr, jlongArray inputs,
  223. jobjectArray dims) {
  224. std::vector<std::vector<int>> c_dims;
  225. auto *pointer = reinterpret_cast<void *>(session_ptr);
  226. if (pointer == nullptr) {
  227. MS_LOGE("Session pointer from java is nullptr");
  228. return false;
  229. }
  230. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  231. auto input_size = static_cast<int>(env->GetArrayLength(inputs));
  232. jlong *input_data = env->GetLongArrayElements(inputs, nullptr);
  233. std::vector<mindspore::tensor::MSTensor *> c_inputs;
  234. for (int i = 0; i < input_size; i++) {
  235. auto *tensor_pointer = reinterpret_cast<void *>(input_data[i]);
  236. if (tensor_pointer == nullptr) {
  237. MS_LOGE("Tensor pointer from java is nullptr");
  238. return false;
  239. }
  240. auto *ms_tensor_ptr = static_cast<mindspore::tensor::MSTensor *>(tensor_pointer);
  241. c_inputs.push_back(ms_tensor_ptr);
  242. }
  243. auto tensor_size = static_cast<int>(env->GetArrayLength(dims));
  244. for (int i = 0; i < tensor_size; i++) {
  245. auto array = static_cast<jintArray>(env->GetObjectArrayElement(dims, i));
  246. auto dim_size = static_cast<int>(env->GetArrayLength(array));
  247. jint *dim_data = env->GetIntArrayElements(array, nullptr);
  248. std::vector<int> tensor_dims(dim_size);
  249. for (int j = 0; j < dim_size; j++) {
  250. tensor_dims[j] = dim_data[j];
  251. }
  252. c_dims.push_back(tensor_dims);
  253. env->ReleaseIntArrayElements(array, dim_data, JNI_ABORT);
  254. env->DeleteLocalRef(array);
  255. }
  256. int ret = lite_session_ptr->Resize(c_inputs, c_dims);
  257. return (jboolean)(ret == mindspore::lite::RET_OK);
  258. }
  259. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_export(JNIEnv *env, jobject thiz,
  260. jlong session_ptr,
  261. jstring model_name,
  262. jint model_type,
  263. jint quantization_type) {
  264. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  265. if (session_pointer == nullptr) {
  266. MS_LOGE("Session pointer from java is nullptr");
  267. return (jboolean) false;
  268. }
  269. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  270. auto ret = lite_session_ptr->Export(env->GetStringUTFChars(model_name, JNI_FALSE),
  271. static_cast<mindspore::lite::ModelType>(model_type),
  272. static_cast<mindspore::lite::QuantizationType>(quantization_type));
  273. return (jboolean)(ret == 0);
  274. }
  275. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_train(JNIEnv *env, jobject thiz,
  276. jlong session_ptr) {
  277. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  278. if (session_pointer == nullptr) {
  279. MS_LOGE("Session pointer from java is nullptr");
  280. return (jboolean) false;
  281. }
  282. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  283. auto ret = lite_session_ptr->Train();
  284. return (jboolean)(ret == mindspore::lite::RET_OK);
  285. }
  286. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_eval(JNIEnv *env, jobject thiz,
  287. jlong session_ptr) {
  288. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  289. if (session_pointer == nullptr) {
  290. MS_LOGE("Session pointer from java is nullptr");
  291. return (jboolean) false;
  292. }
  293. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  294. auto ret = lite_session_ptr->Eval();
  295. return (jboolean)(ret == mindspore::lite::RET_OK);
  296. }
  297. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_isTrain(JNIEnv *env, jobject thiz,
  298. jlong session_ptr) {
  299. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  300. if (session_pointer == nullptr) {
  301. MS_LOGE("Session pointer from java is nullptr");
  302. return (jboolean) false;
  303. }
  304. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  305. auto ret = lite_session_ptr->IsTrain();
  306. return (jboolean)(ret);
  307. }
  308. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_isEval(JNIEnv *env, jobject thiz,
  309. jlong session_ptr) {
  310. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  311. if (session_pointer == nullptr) {
  312. MS_LOGE("Session pointer from java is nullptr");
  313. return (jboolean) false;
  314. }
  315. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  316. auto ret = lite_session_ptr->IsEval();
  317. return (jboolean)(ret);
  318. }
  319. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_setLearningRate(JNIEnv *env, jobject thiz,
  320. jlong session_ptr,
  321. jfloat learning_rate) {
  322. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  323. if (session_pointer == nullptr) {
  324. MS_LOGE("Session pointer from java is nullptr");
  325. return (jboolean) false;
  326. }
  327. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  328. auto ret = lite_session_ptr->SetLearningRate(learning_rate);
  329. return (jboolean)(ret == mindspore::lite::RET_OK);
  330. }
  331. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_setupVirtualBatch(JNIEnv *env, jobject thiz,
  332. jlong session_ptr,
  333. jint virtual_batch_factor,
  334. jfloat learning_rate,
  335. jfloat momentum) {
  336. auto *session_pointer = reinterpret_cast<void *>(session_ptr);
  337. if (session_pointer == nullptr) {
  338. MS_LOGE("Session pointer from java is nullptr");
  339. return (jboolean) false;
  340. }
  341. auto *lite_session_ptr = static_cast<mindspore::session::LiteSession *>(session_pointer);
  342. auto ret = lite_session_ptr->SetupVirtualBatch(virtual_batch_factor, learning_rate, momentum);
  343. return (jboolean)(ret == mindspore::lite::RET_OK);
  344. }
  345. extern "C" JNIEXPORT jboolean JNICALL Java_com_mindspore_lite_LiteSession_updateFeatures(JNIEnv *env, jclass,
  346. jlong session_ptr,
  347. jlongArray features) {
  348. jsize size = static_cast<int>(env->GetArrayLength(features));
  349. jlong *input_data = env->GetLongArrayElements(features, nullptr);
  350. std::vector<mindspore::tensor::MSTensor *> newFeatures;
  351. for (int i = 0; i < size; ++i) {
  352. auto *tensor_pointer = reinterpret_cast<void *>(input_data[i]);
  353. if (tensor_pointer == nullptr) {
  354. MS_LOGE("Tensor pointer from java is nullptr");
  355. return false;
  356. }
  357. auto *ms_tensor_ptr = static_cast<mindspore::tensor::MSTensor *>(tensor_pointer);
  358. newFeatures.emplace_back(ms_tensor_ptr);
  359. }
  360. auto session = reinterpret_cast<mindspore::session::LiteSession *>(session_ptr);
  361. auto ret = session->UpdateFeatureMaps(newFeatures);
  362. return (jboolean)(ret == mindspore::lite::RET_OK);
  363. }
  364. extern "C" JNIEXPORT jobject JNICALL Java_com_mindspore_lite_LiteSession_getFeaturesMap(JNIEnv *env, jobject thiz,
  365. jlong session_ptr) {
  366. jclass array_list = env->FindClass("java/util/ArrayList");
  367. jmethodID array_list_construct = env->GetMethodID(array_list, "<init>", "()V");
  368. jobject ret = env->NewObject(array_list, array_list_construct);
  369. jmethodID array_list_add = env->GetMethodID(array_list, "add", "(Ljava/lang/Object;)Z");
  370. jclass long_object = env->FindClass("java/lang/Long");
  371. jmethodID long_object_construct = env->GetMethodID(long_object, "<init>", "(J)V");
  372. auto *pointer = reinterpret_cast<void *>(session_ptr);
  373. if (pointer == nullptr) {
  374. MS_LOGE("Session pointer from java is nullptr");
  375. return ret;
  376. }
  377. auto *train_session_ptr = static_cast<mindspore::session::LiteSession *>(pointer);
  378. auto inputs = train_session_ptr->GetFeatureMaps();
  379. for (auto input : inputs) {
  380. jobject tensor_addr = env->NewObject(long_object, long_object_construct, jlong(input));
  381. env->CallBooleanMethod(ret, array_list_add, tensor_addr);
  382. }
  383. return ret;
  384. }