dispatch_process.cpp 19 KB

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