dispatch_process.cpp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609
  1. //
  2. // Created by huli on 2021/3/22.
  3. //
  4. #include "dispatch_process.h"
  5. #include "../system/system_communication.h"
  6. #include "../dispatch/dispatch_manager.h"
  7. Dispatch_process::Dispatch_process()
  8. {
  9. m_dispatch_process_status = DISPATCH_PROCESS_STATUS_UNKNOW;
  10. m_dispatch_process_type = DISPATCH_PROCESS_TYPE_UNKNOW;
  11. m_dispatch_source = 0;
  12. m_dispatch_destination = 0;
  13. m_dispatch_process_catcher_motion = CATCHER_MOTION_UNKNOW;
  14. m_dispatch_process_carrier_motion = CARRIER_MOTION_UNKNOW;
  15. }
  16. Dispatch_process::~Dispatch_process()
  17. {
  18. Dispatch_process_uninit();
  19. }
  20. //初始化, 就把主控发送的请求传入即可.
  21. Error_manager Dispatch_process::Dispatch_process_init(message::Dispatch_request_msg dispatch_request_msg)
  22. {
  23. if ( dispatch_request_msg.base_info().has_timeout_ms() )
  24. {
  25. m_timeout_ms = dispatch_request_msg.base_info().timeout_ms() - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  26. }
  27. else
  28. {
  29. m_timeout_ms = DISPATCH_PROCESS_TIMEOUT_MS - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  30. }
  31. m_command_key = dispatch_request_msg.command_key();
  32. m_start_time = std::chrono::system_clock::now();
  33. if ( dispatch_request_msg.dispatch_motion_direction() == message::E_STORE_CAR )
  34. {
  35. m_dispatch_process_type = DISPATCH_PROCESS_STORE;
  36. m_dispatch_source = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  37. m_dispatch_destination = dispatch_request_msg.parkspace_info().parkspace_id() + PARKSPACE_ID_BASE;
  38. Common_data::copy_data(m_parkspace_information, dispatch_request_msg.parkspace_info());
  39. Common_data::copy_data(m_car_measure_information, dispatch_request_msg.locate_information());
  40. }
  41. else if( dispatch_request_msg.dispatch_motion_direction() == message::E_PICKUP_CAR )
  42. {
  43. m_dispatch_process_type = DISPATCH_PROCESS_PICKUP;
  44. m_dispatch_source = dispatch_request_msg.parkspace_info().parkspace_id() + PARKSPACE_ID_BASE;
  45. m_dispatch_destination = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  46. Common_data::copy_data(m_parkspace_information, dispatch_request_msg.parkspace_info());
  47. }
  48. else
  49. {
  50. m_dispatch_process_type = DISPATCH_PROCESS_TYPE_UNKNOW;
  51. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  52. " Dispatch_process::Dispatch_process_init ERROR ");
  53. }
  54. m_dispatch_request_msg = dispatch_request_msg;
  55. m_dispatch_process_status = DISPATCH_PROCESS_CREATED;
  56. return Error_code::SUCCESS;
  57. }
  58. //反初始化
  59. Error_manager Dispatch_process::Dispatch_process_uninit()
  60. {
  61. return Error_code::SUCCESS;
  62. }
  63. void Dispatch_process::Main()
  64. {
  65. Error_manager t_error;
  66. //主流程, 循环执行
  67. while ( std::chrono::system_clock::now() - m_start_time < std::chrono::milliseconds(m_timeout_ms) )
  68. {
  69. std::this_thread::sleep_for(std::chrono::microseconds(1));
  70. switch ( m_dispatch_process_status )
  71. {
  72. case DISPATCH_PROCESS_CREATED:
  73. {
  74. //检查调度请求
  75. m_result = check_dispatch_request_msg();
  76. if ( m_result !=Error_code::SUCCESS)
  77. {
  78. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  79. break;
  80. }
  81. //发送调度总计划
  82. m_result = send_dispatch_plan_request_msg();
  83. if ( m_result !=Error_code::SUCCESS)
  84. {
  85. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  86. break;
  87. }
  88. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  89. m_dispatch_process_status = DISPATCH_PROCESS_READY;
  90. break;
  91. }
  92. case DISPATCH_PROCESS_READY:
  93. {
  94. //等待控制指令
  95. m_result = wait_dispatch_control_request_msg();
  96. if ( m_result !=Error_code::SUCCESS)
  97. {
  98. //不成功, 就表示没有新的指令, 那么什么都不做, 原地待命
  99. }
  100. else
  101. {
  102. //流程正常, 就去连接设备
  103. m_dispatch_process_status = DISPATCH_PROCESS_CONNECT_DEVICE;
  104. break;
  105. }
  106. //等待调度总计划答复
  107. m_result = wait_dispatch_plan_response_msg();
  108. if ( m_result !=Error_code::SUCCESS)
  109. {
  110. //不成功, 就表示没有总计划答复, 那么什么都不做, 原地待命
  111. }
  112. else
  113. {
  114. //流程正常, 就进入完成状态,
  115. m_dispatch_process_status = DISPATCH_PROCESS_OVER;
  116. break;
  117. }
  118. break;
  119. }
  120. case DISPATCH_PROCESS_CONNECT_DEVICE:
  121. {
  122. //连接调度设备
  123. m_result = connect_dispatch_device();
  124. if ( m_result !=Error_code::SUCCESS)
  125. {
  126. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  127. break;
  128. }
  129. //流程正常, 就进入工作状态,
  130. m_dispatch_process_status = DISPATCH_PROCESS_WORKING;
  131. break;
  132. break;
  133. }
  134. case DISPATCH_PROCESS_WORKING:
  135. {
  136. break;
  137. }
  138. case DISPATCH_PROCESS_RESPONSE:
  139. {
  140. break;
  141. }
  142. case DISPATCH_PROCESS_OVER:
  143. {
  144. //发送调度答复, 发给主控的
  145. m_result = send_dispatch_response_msg();
  146. if ( m_result !=Error_code::SUCCESS)
  147. {
  148. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  149. break;
  150. }
  151. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  152. m_dispatch_process_status = DISPATCH_PROCESS_RELEASE;
  153. break;
  154. }
  155. case DISPATCH_PROCESS_RELEASE:
  156. {
  157. //通知调度管理, 释放资源,
  158. m_result = release_resource();
  159. if ( m_result !=Error_code::SUCCESS)
  160. {
  161. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  162. break;
  163. }
  164. //在这里, 整个流程彻底结束, 之后线程池会自动回收 这个流程对象的资源
  165. return;
  166. break;
  167. }
  168. case DISPATCH_PROCESS_FAULT:
  169. {
  170. break;
  171. }
  172. default:
  173. {
  174. break;
  175. }
  176. }
  177. }
  178. //任务超时
  179. return;
  180. }
  181. //检查调度请求
  182. Error_manager Dispatch_process::check_dispatch_request_msg()
  183. {
  184. std::unique_lock<std::mutex> t_lock(m_lock);
  185. return Error_code::SUCCESS;
  186. }
  187. //发送调度总计划
  188. Error_manager Dispatch_process::send_dispatch_plan_request_msg()
  189. {
  190. std::unique_lock<std::mutex> t_lock(m_lock);
  191. m_dispatch_plan_request_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_plan_request_msg);
  192. m_dispatch_plan_request_msg.mutable_base_info()->set_timeout_ms(m_timeout_ms);
  193. m_dispatch_plan_request_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_mamager);
  194. m_dispatch_plan_request_msg.mutable_base_info()->set_receiver(message::Communicator::eDispatch_control);
  195. m_dispatch_plan_request_msg.set_command_key(m_command_key);
  196. m_dispatch_plan_request_msg.set_dispatch_task_type((message::Dispatch_task_type)m_dispatch_process_type);
  197. m_dispatch_plan_request_msg.set_dispatch_source(m_dispatch_source);
  198. m_dispatch_plan_request_msg.set_dispatch_destination(m_dispatch_destination);
  199. //这里不写错误码
  200. std::string t_msg = m_dispatch_plan_request_msg.SerializeAsString();
  201. System_communication::get_instance_references().encapsulate_msg(t_msg);
  202. return Error_code::SUCCESS;
  203. }
  204. //等待控制指令
  205. Error_manager Dispatch_process::wait_dispatch_control_request_msg()
  206. {
  207. std::unique_lock<std::mutex> t_lock(m_lock);
  208. //key不相等 就表示 收到了新的控制指令
  209. if ( m_dispatch_control_request_msg.command_key() == m_dispatch_control_response_msg.command_key() )
  210. {
  211. return Error_code::NODATA;
  212. }
  213. else
  214. {
  215. return Error_code::SUCCESS;
  216. }
  217. }
  218. //连接调度设备
  219. Error_manager Dispatch_process::connect_dispatch_device()
  220. {
  221. std::unique_lock<std::mutex> t_lock(m_lock);
  222. Error_manager t_error;
  223. //机器手的配置 准备工作
  224. if ( m_dispatch_control_request_msg.dispatch_device_type() >= message::Dispatch_device_type::ROBOT_1 &&
  225. m_dispatch_control_request_msg.dispatch_device_type() <= message::Dispatch_device_type::ROBOT_2 )
  226. {
  227. //找到对应的设备
  228. if ( m_dispatch_control_request_msg.dispatch_device_type() == message::Dispatch_device_type::ROBOT_1 )
  229. {
  230. mp_catcher = Dispatch_manager::get_instance_references().m_catcher_map[0];
  231. }
  232. if ( m_dispatch_control_request_msg.dispatch_device_type() == message::Dispatch_device_type::ROBOT_2 )
  233. {
  234. mp_catcher = Dispatch_manager::get_instance_references().m_catcher_map[1];
  235. }
  236. //检查设备状态
  237. if ( mp_catcher->check_status() == Error_code::SUCCESS &&
  238. mp_catcher->m_actual_device_status == Dispatch_device_base::DEVICE_READY &&
  239. mp_catcher->m_actual_load_status == Dispatch_device_base::NO_CAR)
  240. {
  241. //创建任务单
  242. mp_catcher_task = std::shared_ptr<Task_Base>(new Catcher_task);
  243. mp_catcher_task->task_init(NULL,std::chrono::milliseconds(15000));
  244. Catcher_task * tp_catcher_task = (Catcher_task *)mp_catcher_task.get();
  245. //第一次发送 空的唯一码, 可以和设备建立联系
  246. tp_catcher_task->m_request_key = "";
  247. tp_catcher_task->m_request_x = mp_catcher->m_actual_x;
  248. tp_catcher_task->m_request_y = mp_catcher->m_actual_y;
  249. tp_catcher_task->m_request_b = mp_catcher->m_actual_b;
  250. tp_catcher_task->m_request_z = mp_catcher->m_actual_z;
  251. tp_catcher_task->m_request_d1 = mp_catcher->m_actual_d1;
  252. tp_catcher_task->m_request_d2 = mp_catcher->m_actual_d2;
  253. tp_catcher_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  254. tp_catcher_task->m_request_clamp_motion = (Catcher_task::Clamp_motion)mp_catcher->m_actual_clamp_motion1;
  255. t_error = mp_catcher->execute_task(mp_catcher_task, Dispatch_device_base::E_ONE_LEVEL);
  256. if ( t_error != Error_code::SUCCESS )
  257. {
  258. return t_error;
  259. }
  260. }
  261. else
  262. {
  263. return Error_manager(Error_code::DISPATCH_PROCESS_DEVICE_STATUS_ERROR, Error_level::MINOR_ERROR,
  264. " Dispatch_process::excute_robot_catch_car_from_inlet device_status error ");
  265. }
  266. //设置起点
  267. if ( m_dispatch_control_request_msg.dispatch_source() == 0 )
  268. {
  269. m_source_coordinates.x = 0;
  270. m_source_coordinates.y = 0;
  271. m_source_coordinates.z = 0;
  272. }
  273. else if ( m_dispatch_control_request_msg.dispatch_source() > 0 && m_dispatch_control_request_msg.dispatch_source() <= 165)
  274. {
  275. m_source_coordinates = Dispatch_coordinates::get_instance_references().m_packspace_coordinates[m_dispatch_control_request_msg.dispatch_source()];
  276. }
  277. else
  278. {
  279. m_source_coordinates = Dispatch_coordinates::get_instance_references().m_catcher_coordinates[m_dispatch_control_request_msg.dispatch_source()];
  280. }
  281. //设置终点
  282. if ( m_dispatch_control_request_msg.dispatch_destination() == 0 )
  283. {
  284. m_destination_coordinates.x = 0;
  285. m_destination_coordinates.y = 0;
  286. m_destination_coordinates.z = 0;
  287. }
  288. else if ( m_dispatch_control_request_msg.dispatch_destination() > 0 && m_dispatch_control_request_msg.dispatch_destination() <= 165)
  289. {
  290. m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_packspace_coordinates[m_dispatch_control_request_msg.dispatch_destination()];
  291. }
  292. else
  293. {
  294. m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_catcher_coordinates[m_dispatch_control_request_msg.dispatch_destination()];
  295. }
  296. }
  297. //搬运器的配置 准备工作
  298. else if ( m_dispatch_control_request_msg.dispatch_device_type() >= message::Dispatch_device_type::CARRIER_1 &&
  299. m_dispatch_control_request_msg.dispatch_device_type() <= message::Dispatch_device_type::CARRIER_3 )
  300. {
  301. //找到对应的设备
  302. if ( m_dispatch_control_request_msg.dispatch_device_type() == message::Dispatch_device_type::CARRIER_1 )
  303. {
  304. mp_carrier = Dispatch_manager::get_instance_references().m_carrier_map[0];
  305. }
  306. if ( m_dispatch_control_request_msg.dispatch_device_type() == message::Dispatch_device_type::CARRIER_2 )
  307. {
  308. mp_carrier = Dispatch_manager::get_instance_references().m_carrier_map[1];
  309. }
  310. if ( m_dispatch_control_request_msg.dispatch_device_type() == message::Dispatch_device_type::CARRIER_3 )
  311. {
  312. mp_carrier = Dispatch_manager::get_instance_references().m_carrier_map[1];
  313. }
  314. //检查设备状态
  315. if ( mp_carrier->check_status() == Error_code::SUCCESS &&
  316. mp_carrier->m_actual_device_status == Dispatch_device_base::DEVICE_READY &&
  317. mp_carrier->m_actual_load_status == Dispatch_device_base::NO_CAR)
  318. {
  319. //创建任务单
  320. mp_carrier_task = std::shared_ptr<Task_Base>(new Carrier_task);
  321. mp_carrier_task->task_init(NULL,std::chrono::milliseconds(15000));
  322. Carrier_task * tp_carrier_task = (Carrier_task *)mp_carrier_task.get();
  323. //第一次发送 空的唯一码, 可以和设备建立联系
  324. tp_carrier_task->m_request_key = "";
  325. tp_carrier_task->m_request_x = mp_carrier->m_actual_x;
  326. tp_carrier_task->m_request_y = mp_carrier->m_actual_y;
  327. tp_carrier_task->m_request_z = mp_carrier->m_actual_z;
  328. tp_carrier_task->m_request_y1 = mp_carrier->m_actual_y1;
  329. tp_carrier_task->m_request_y2 = mp_carrier->m_actual_y2;
  330. tp_carrier_task->m_request_clamp_motion = (Carrier_task::Clamp_motion)mp_carrier->m_actual_clamp_motion1;
  331. tp_carrier_task->m_request_joint_motion_x = (Carrier_task::Joint_motion)mp_carrier->m_actual_joint_motion_x1;
  332. tp_carrier_task->m_request_joint_motion_y = Carrier_task::Joint_motion::E_JOINT_NO_ACTION;
  333. tp_carrier_task->m_request_space_id = 0;
  334. tp_carrier_task->m_request_floor_id = 0;
  335. tp_carrier_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  336. t_error = mp_carrier->execute_task(mp_catcher_task, Dispatch_device_base::E_ONE_LEVEL);
  337. if ( t_error != Error_code::SUCCESS )
  338. {
  339. return t_error;
  340. }
  341. }
  342. else
  343. {
  344. return Error_manager(Error_code::DISPATCH_PROCESS_DEVICE_STATUS_ERROR, Error_level::MINOR_ERROR,
  345. " Dispatch_process::excute_robot_catch_car_from_inlet device_status error ");
  346. }
  347. //设置起点
  348. if ( m_dispatch_control_request_msg.dispatch_source() == 0 )
  349. {
  350. m_source_coordinates.x = 0;
  351. m_source_coordinates.y = 0;
  352. m_source_coordinates.z = 0;
  353. }
  354. else if ( m_dispatch_control_request_msg.dispatch_source() > 0 && m_dispatch_control_request_msg.dispatch_source() <= 165)
  355. {
  356. m_source_coordinates = Dispatch_coordinates::get_instance_references().m_packspace_coordinates[m_dispatch_control_request_msg.dispatch_source()];
  357. }
  358. else
  359. {
  360. m_source_coordinates = Dispatch_coordinates::get_instance_references().m_carrier_coordinates[m_dispatch_control_request_msg.dispatch_source()];
  361. }
  362. //设置终点
  363. if ( m_dispatch_control_request_msg.dispatch_destination() == 0 )
  364. {
  365. m_destination_coordinates.x = 0;
  366. m_destination_coordinates.y = 0;
  367. m_destination_coordinates.z = 0;
  368. }
  369. else if ( m_dispatch_control_request_msg.dispatch_destination() > 0 && m_dispatch_control_request_msg.dispatch_destination() <= 165)
  370. {
  371. m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_packspace_coordinates[m_dispatch_control_request_msg.dispatch_destination()];
  372. }
  373. else
  374. {
  375. m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_carrier_coordinates[m_dispatch_control_request_msg.dispatch_destination()];
  376. }
  377. }
  378. return Error_code::SUCCESS;
  379. }
  380. //检查机器手任务单
  381. Error_manager Dispatch_process::check_catcher_task()
  382. {
  383. if ( mp_catcher_task.get() == NULL )
  384. {
  385. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  386. "Dispatch_process::check_catcher_task POINTER IS NULL ");
  387. }
  388. else
  389. {
  390. Catcher_task * tp_catcher_task = (Catcher_task *)mp_catcher_task.get();
  391. if ( tp_catcher_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  392. {
  393. return Error_code::SUCCESS;
  394. }
  395. else if ( tp_catcher_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  396. {
  397. return tp_catcher_task->get_task_error_manager();
  398. }
  399. else if ( tp_catcher_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING &&
  400. tp_catcher_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED &&
  401. tp_catcher_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED)
  402. {
  403. return Error_code::NODATA;
  404. }
  405. }
  406. }
  407. //检查搬运器任务单
  408. Error_manager Dispatch_process::check_carrier_task()
  409. {
  410. if ( mp_carrier_task.get() == NULL )
  411. {
  412. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  413. "Dispatch_process::check_carrier_task POINTER IS NULL ");
  414. }
  415. else
  416. {
  417. Catcher_task * tp_carrier_task = (Catcher_task *)mp_carrier_task.get();
  418. if ( tp_carrier_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  419. {
  420. return Error_code::SUCCESS;
  421. }
  422. else if ( tp_carrier_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  423. {
  424. return tp_carrier_task->get_task_error_manager();
  425. }
  426. else if ( tp_carrier_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING &&
  427. tp_carrier_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED &&
  428. tp_carrier_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED)
  429. {
  430. return Error_code::NODATA;
  431. }
  432. }
  433. }
  434. //检查通道口任务单
  435. Error_manager Dispatch_process::check_passageway_task()
  436. {
  437. if ( mp_passageway_task.get() == NULL )
  438. {
  439. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  440. "Dispatch_process::check_passageway_task POINTER IS NULL ");
  441. }
  442. else
  443. {
  444. Catcher_task * tp_passageway_task = (Catcher_task *)mp_passageway_task.get();
  445. if ( tp_passageway_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  446. {
  447. return Error_code::SUCCESS;
  448. }
  449. else if ( tp_passageway_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  450. {
  451. return tp_passageway_task->get_task_error_manager();
  452. }
  453. else if ( tp_passageway_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING &&
  454. tp_passageway_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED &&
  455. tp_passageway_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED)
  456. {
  457. return Error_code::NODATA;
  458. }
  459. }
  460. }
  461. //执行调度控制指令, 并根据完成情况给答复
  462. Error_manager Dispatch_process::excute_dispatch_control()
  463. {
  464. return Error_code::SUCCESS;
  465. }
  466. //机器手去入口抓车(例如:机器手移动到2号入口上方,然后下降到一楼抓车,最后上升到最上方)
  467. Error_manager Dispatch_process::excute_robot_catch_car_from_inlet()
  468. {
  469. std::unique_lock<std::mutex> t_lock(m_lock);
  470. Error_manager t_error;
  471. //设备的动作也使用外部的Main()的线程来循环
  472. static int s_step = 0;
  473. Catcher_task * tp_catcher_task = NULL;
  474. if ( mp_catcher.get() == NULL || mp_catcher_task.get() == NULL )
  475. {
  476. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  477. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  478. }
  479. else
  480. {
  481. tp_catcher_task = (Catcher_task *)mp_catcher_task.get();
  482. }
  483. if ( s_step == 0 )
  484. {
  485. t_error = check_catcher_task();
  486. if ( t_error == Error_code::SUCCESS )
  487. {
  488. s_step++;//成功完成之后, 并不返回, 直接进入下一步
  489. }
  490. else if( t_error == Error_code::NODATA )
  491. {
  492. //什么也不做, 继续等待任务完成, 此时Main函数会一直循环.
  493. }
  494. else
  495. {
  496. s_step = 0;
  497. return t_error;
  498. }
  499. }
  500. if ( s_step == 1 )
  501. {
  502. std::unique_lock<std::mutex> t_lock1(m_lock);
  503. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  504. char t_key[50] = {0};
  505. sprintf(t_key, "%s+%d+%d", m_dispatch_control_request_msg.command_key().c_str(), m_dispatch_control_request_msg.dispatch_task_type(), s_step);
  506. tp_catcher_task->m_respons_key = t_key;
  507. //机器手z轴移到最高点.
  508. tp_catcher_task->m_request_z = Dispatch_coordinates::get_instance_references().m_catcher_4th_floor_z;
  509. }
  510. }
  511. //机器手把车放到中跑车上面(例如:机器手下降到中跑车上放车,最后上升到最上方)(通过目标点 指定放到哪一个中跑车上)
  512. Error_manager Dispatch_process::excute_robot_put_car_to_carrier()
  513. {
  514. }
  515. //执行通道口动作
  516. Error_manager Dispatch_process::excute_passageway_motion()
  517. {
  518. return Error_code::SUCCESS;
  519. }
  520. //等待调度总计划答复
  521. Error_manager Dispatch_process::wait_dispatch_plan_response_msg()
  522. {
  523. std::unique_lock<std::mutex> t_lock(m_lock);
  524. //key 相等 就表示 收到了总计划答复
  525. if ( m_dispatch_plan_request_msg.command_key() == m_dispatch_plan_response_msg.command_key() )
  526. {
  527. return Error_code::SUCCESS;
  528. }
  529. else
  530. {
  531. return Error_code::NODATA;
  532. }
  533. }
  534. //发送调度答复, 发给主控的
  535. Error_manager Dispatch_process::send_dispatch_response_msg()
  536. {
  537. std::unique_lock<std::mutex> t_lock(m_lock);
  538. m_dispatch_response_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_response_msg);
  539. m_dispatch_response_msg.mutable_base_info()->set_timeout_ms(m_timeout_ms);
  540. m_dispatch_response_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_mamager);
  541. m_dispatch_response_msg.mutable_base_info()->set_receiver(message::Communicator::eMain);
  542. m_dispatch_response_msg.set_command_key(m_command_key);
  543. m_dispatch_response_msg.mutable_error_manager()->CopyFrom(m_dispatch_plan_response_msg.error_manager());
  544. std::string t_msg = m_dispatch_response_msg.SerializeAsString();
  545. System_communication::get_instance_references().encapsulate_msg(t_msg);
  546. return Error_code::SUCCESS;
  547. }
  548. //通知调度管理, 释放资源,
  549. Error_manager Dispatch_process::release_resource()
  550. {
  551. return Dispatch_manager::get_instance_references().release_dispatch_process(m_command_key);
  552. }