dispatch_command.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. #ifndef __DISPATCH_COMMAND_HH__
  2. #define __DISPATCH_COMMAND_HH__
  3. #include "../tool/singleton.h"
  4. #include "../tool/thread_condition.h"
  5. #include "../error_code/error_code.h"
  6. #include "../dispatch/database_controller.h"
  7. #include "../message/message.pb.h"
  8. #include "../tool/common_data.h"
  9. #include <string>
  10. #include <map>
  11. #include <glog/logging.h>
  12. //调度指令模块, 主要是与数据库的表 command_queue 同步, 然后按照一定的策略
  13. class Dispatch_command
  14. {
  15. public:
  16. #define PARK_TIME_FLAG 101 //存车时间标记, 用于记录时差
  17. #define PICK_TIME_FLAG 102 //取车时间标记, 用于记录时差120
  18. #ifdef CHUTIAN_PROJECT_PROJECT
  19. #define SORT_LOSS_RATIO 1 //排序时, 排序编号间和楼层距离的比例, 默认1:1
  20. #endif//CHUTIAN_PROJECT_PROJECT
  21. #ifdef SHANGGUJIE_PROJECT_PROJECT
  22. #define SORT_LOSS_RATIO 0//厦门车库暂时不允许插队, 按时间顺序
  23. #endif//SHANGGUJIE_PROJECT_PROJECT
  24. //调度指令模块 的状态
  25. enum Dispatch_command_status
  26. {
  27. E_DISPATCH_COMMAND_UNKNOW = 0, //未知
  28. E_DISPATCH_COMMAND_READY = 1, //准备,待机
  29. E_DISPATCH_COMMAND_BUSY = 2, //工作正忙
  30. E_DISPATCH_COMMAND_DISCONNECT = 3, //断连
  31. E_DISPATCH_COMMAND_FAULT = 100, //故障
  32. };
  33. //调度指令, 格式和数据库的 command_queue 保持一致
  34. struct Dispatch_command_info
  35. {
  36. std::string m_car_number; //车牌号
  37. std::string m_primary_key; //唯一码
  38. int m_unit; //单元号,
  39. int m_terminal_id; //终端号,
  40. int m_queue_id; //排序的id,
  41. int m_type; //指令类型, 0无效, 1存车, 2取车,
  42. int m_statu; //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  43. int m_import_id; //入口id, 1~6
  44. int m_export_id; //出口id, 1~6
  45. float m_height; //车高
  46. std::string m_space_info_string; //车位信息的DebugString, 默认没有, 存车要根据感测信息的车高去申请车位, 取车根据车牌号找车位
  47. parkspace_info m_space_info_msg; //车位信息的proto格式
  48. std::string m_measure_info_string; //感测信息的DebugString, 里面自带车高, 小1.5 中1.7 大1.9,
  49. measure_info m_measure_info_msg; //感测信息的proto格式
  50. std::string m_car_number_info_string; //车牌信息,包含图片
  51. plate_number_info m_car_number_info_msg; //车牌信息,包含图片
  52. int m_useless_distance; //空跑的路程,
  53. };
  54. //调度车位信息, 格式和数据库的 space 保持一致
  55. struct Dispatch_space_info
  56. {
  57. int m_id; //车位id
  58. int m_serial_id; //排序id
  59. int m_table_id; //标签id
  60. int m_unit; //单元号,
  61. int m_floor; //车位楼层
  62. int m_room_id; //层内id
  63. float m_height; //车位高度, 小1.55 中1.75 大2.2,
  64. std::string m_primary_key; //key
  65. std::string m_car_number; //车牌号
  66. int m_statu; //车位状态, 0可用, 1故障
  67. std::string m_space_info_string; //车位信息的DebugString, 默认没有, 存车要根据感测信息的车高去申请车位, 取车根据车牌号找车位
  68. parkspace_info m_space_info_msg; //车位信息的proto格式
  69. std::string m_measure_info_string; //感测信息的DebugString, 里面自带车高, 小1.5 中1.7 大1.9,
  70. measure_info m_measure_info_msg; //感测信息的proto格式
  71. };
  72. //调度车辆信息, 格式和数据库的 vehicle 保持一致
  73. struct Dispatch_vehicle_info
  74. {
  75. std::string m_car_number; //车牌号
  76. std::string m_primary_key; //唯一码
  77. std::string m_actually_measure_info; //感测信息的DebugString, 里面自带车高, 小1.5 中1.7 大1.9,
  78. measure_info m_actually_measure_info_msg; //感测信息的proto格式
  79. };
  80. public:
  81. Dispatch_command();
  82. Dispatch_command(const Dispatch_command& other)= default;
  83. Dispatch_command& operator =(const Dispatch_command& other)= default;
  84. ~Dispatch_command();
  85. public://API functions
  86. #ifdef SHANGGUJIE_PROJECT_PROJECT
  87. //存车指令入队, 检查节点直接通过rabbitmq发送给调度, 调度接受后数据库指令入队,
  88. Error_manager insert_park_command(park_table park_command);
  89. //存车指令入队, 检查节点直接通过rabbitmq发送给调度, 调度接受后数据库指令入队,
  90. Error_manager insert_park_command(park_table park_command, Dispatch_command::Dispatch_space_info dispatch_space_info);
  91. //取车指令入队, 检查节点直接通过rabbitmq发送给调度, 调度接受后数据库指令入队,
  92. Error_manager insert_pick_command(pick_table pick_command);
  93. //取车指令入队, 检查节点直接通过rabbitmq发送给调度, 调度接受后数据库指令入队,
  94. Error_manager insert_pick_command(pick_table pick_command, Dispatch_command::Dispatch_space_info dispatch_space_info);
  95. #endif//SHANGGUJIE_PROJECT_PROJECT
  96. //检查指令队列, 优先恢复未完成的指令,其次在执行新的指令
  97. //调度开始前, 向数据库发送请求的相关操作, 输入 穿梭机所在的楼层, 调度id 0~2, 空闲出口id, 如果不是0,就表示有空闲的出口
  98. Error_manager dispatch_request_to_sql(int plc_floor, int dispatch_id, int outlet_ready);
  99. //调度完成后, 向数据库发送答复的相关操作
  100. Error_manager dispatch_response_to_sql(Error_manager error);
  101. //调度 , 向数据库 重新分配车位,
  102. Error_manager dispatch_reallocate_to_sql(Common_data::Car_type reallocate_car_type, int outlet_ready);
  103. //检查出口是否空闲, 检查指令队列的取车完成的出口id是否存在, 不存在就是空闲,返回成功
  104. Error_manager check_export_id_is_ready(int export_id);
  105. //检查出口取车是否完成, 指定的出口有取车完成指令就返回成功, 否则报错.
  106. Error_manager check_pickup_is_finish(int unit_id, int export_id);
  107. //检查入口存车是否开始, 指定的入口有存车开始指令就返回成功, 否则报错.
  108. Error_manager check_park_is_start(int import_id);
  109. //获取指定入口的 存车流程的 唯一码,
  110. Error_manager get_primary_key_for_store(int import_id, std::string & primary_key );
  111. //删除 指令队列, 根据出口编号
  112. Error_manager delete_command_queue_for_export_id(int unit_id, int export_id);
  113. //添加plc数据储存
  114. Error_manager insert_plc_data(std::string plc_data, float hearbeat);
  115. //查询 取车的车位 取车指令 根据车牌号 查询对应的车位
  116. Error_manager query_dispatch_space_for_car_number(std::string car_number, parkspace_info & parkspace_info);
  117. //查询 取车的车位 取车指令 根据车牌号 查询对应的车位
  118. Error_manager query_dispatch_space_for_primary_key(std::string primary_key, std::string &car_number, parkspace_info & parkspace_info, measure_info & measure_info);
  119. //查询 取车的车辆感测信息 取车指令 根据key 查询感测信息
  120. Error_manager query_dispatch_vehicle_for_primary_key(std::string primary_key, measure_info & measure_info);
  121. public://get or set member variable
  122. protected://member functions
  123. public:
  124. //获取调度指令, 与数据库同步 command_queue, statu指令状态, 0:排队等待, 1正在运行, 2:已经完成
  125. Error_manager query_all_dispatch_command(int statu);
  126. //对调度指令进行排序, 选出最优解, 比较存车和取车
  127. Error_manager sort_dispatch_command_for_total();
  128. //对调度指令进行排序, 选出最优解, 只比较存车
  129. Error_manager sort_dispatch_command_for_park();
  130. //获取 指定车高 指定单元 的车位信息,用于车位分配, 找不到就会报错,
  131. Error_manager query_specify_height_unit_parkspace_info(int unit, float height, float wheel_base, Dispatch_space_info & dispatch_space_info);
  132. //获取 指定车高 指定单元 的空闲车位数量,
  133. Error_manager query_specify_height_unit_parkspace_info(int unit, float height, float wheel_base, int & dispatch_space_count);
  134. //查询空闲车位最优解, 存车指令 根据调度指令最优解 获取 空闲车位最优解
  135. Error_manager query_dispatch_space_optimal(int unit, float height, float wheel_base, Common_data::Car_type & car_type, Dispatch_space_info & dispatch_space_info);
  136. //查询空闲车位最优解, 存车指令 根据调度指令最优解 获取 空闲车位最优解
  137. Error_manager query_dispatch_space_optimal_ex(Common_data::Car_type reallocate_car_type, Dispatch_space_info & dispatch_space_info);
  138. //查询 取车的车位 取车指令 根据车牌号 查询对应的车位
  139. Error_manager query_dispatch_space_for_car_number();
  140. //查询 取车的车辆感测信息 取车指令 根据key 查询感测信息
  141. // Error_manager query_dispatch_vehicle_for_primary_key();
  142. //更新 车位状态, 根据车位ID 修改车牌号即可,
  143. Error_manager update_parkspace_write_car_number();
  144. //更新 车位状态, 存车排队预约车位
  145. Error_manager update_parkspace_write_car_number(park_table park_command, Dispatch_command::Dispatch_space_info dispatch_space_info);
  146. //更新 车位状态, 找到车牌号, 写NULL
  147. Error_manager update_parkspace_clear_car_number();
  148. //更新 车位状态, 找到车牌号, 写NULL by id
  149. Error_manager update_parkspace_clear_car_number_by_id(int space_id, int statu);
  150. //更新车牌图片信息,
  151. Error_manager update_parkspace_write_car_number_info();
  152. //删除车牌图片信息,
  153. Error_manager update_parkspace_clear_car_number_info();
  154. //更新 指令队列, 根据车牌号 修改状态即可, //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  155. Error_manager update_command_queue_for_statu(int statu);
  156. //更新 指令队列, 根据车牌号 修改状态即可, //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  157. // Error_manager update_command_queue_for_statu(int statu, std::string error_description);
  158. //把整个单元的排队指令改为故障
  159. Error_manager update_command_queue_from_wait_to_fault_for_unit(int unit_id);
  160. //删除 指令队列, 根据车牌号 删除指令
  161. Error_manager delete_command_queue_for_car_number();
  162. //制作存车表单
  163. Error_manager create_park_table();
  164. //制作取车表单
  165. Error_manager create_pick_table(int outlet_ready);
  166. //增加 车辆表, 存车指令 完成后添加车辆信息
  167. Error_manager select_vehicle_for_car_number();
  168. //增加 车辆表, 存车指令 完成后添加车辆信息
  169. Error_manager insert_vehicle_for_car_number();
  170. //增加 车辆表, 存车指令 完成后添加车辆信息, park_statu停车状态, 0:不存在, 1:存车中, 2:取车中, 3:在楼上存车
  171. Error_manager updata_vehicle_for_car_number(int park_statu);
  172. //删除 车辆表, 取车指令 完成后删除车辆信息
  173. Error_manager delete_vehicle_for_car_number();
  174. //检查记录表是否提前创建。没有创建就返回成功
  175. Error_manager check_record_for_no_primary_key(std::string primary_key);
  176. //增加 记录表, 存车指令 完成后添加存车记录
  177. Error_manager insert_record_for_park_start();
  178. //更新 记录表, 存车指令 完成后只更新存车开始时间
  179. Error_manager updata_record_for_park_start();
  180. //增加 记录表, 存车指令 完成后添加存车记录
  181. Error_manager insert_record_for_park_start(park_table park_command, Dispatch_command::Dispatch_space_info dispatch_space_info);
  182. //增加 记录表, 存车指令 完成后添加存车记录
  183. Error_manager updata_record_for_park_end();
  184. //更新 记录表, 取车指令 完成后更新取车记录
  185. Error_manager updata_record_for_pick_start();
  186. //更新 记录表, 取车指令 完成后更新取车记录
  187. Error_manager updata_record_for_pick_end();
  188. //更新 记录表, 取车指令 完成后更新取车记录, 撤销指令, 没有取车时间差
  189. Error_manager updata_record_for_pick_end_ex();
  190. //计算汽车在车库的存车时间, 从存车开始到取车结束, 返回 parking_time, 单位秒.
  191. Error_manager get_parking_time(std::string primary_key, int & parking_time );
  192. public:
  193. //获取出入口id 1~2为入口, 3~4为出口,
  194. //输入terminal_id 1~19, 输入 action_mode 1:存车, 2:取车
  195. int get_passway_id(int terminal_id, int action_mode);
  196. protected://member variable
  197. public:
  198. Dispatch_command_status m_dispatch_command_status; //调度指令模块 的状态
  199. std::mutex m_lock; // 锁.
  200. int m_dispatch_id; //调度id, 0-2
  201. int m_unit; //单元号
  202. int m_device_floor; //穿梭机所在的楼层, 存车完在对应的车位楼层, 取车完在1楼
  203. int m_outlet_ready; //取车空闲出口id, 0表示没有出口, 1~6表示空闲出口
  204. std::map<std::string, Dispatch_command_info> m_dispatch_command_map; //调度指令map, 数据库的所有信息
  205. std::string m_car_number_optimal; //调度指令最优解
  206. Dispatch_space_info m_dispatch_space_info[100]; //调度车位最优解, 可以多次重新分配
  207. int m_dispatch_space_info_count; //调度车位最优解, 如果重新分配,这个count就是最新使用的下标
  208. // int m_wait_park_count = 0; //排队存车的数量
  209. // int m_wait_pick_count = 0; //排队取车的数量
  210. // Dispatch_vehicle_info m_dispatch_vehicle_info; //调度车位最优解
  211. // Dispatch_space_info m_dispatch_space_info_reallocate[100]; //调度车位最优解, 重新分配的车位
  212. Common_data::Dispatch_process_type m_dispatch_process_type ; //调度流程类型
  213. park_table m_park_table_msg; //停车表单
  214. pick_table m_pick_table_msg; //取车表单
  215. Common_data::Car_type m_car_type; //车的大小
  216. private:
  217. };
  218. #endif // __DISPATCH_COMMAND_HH__