dispatch_command.h 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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. //调度指令模块 的状态
  17. enum Dispatch_command_status
  18. {
  19. E_DISPATCH_COMMAND_UNKNOW = 0, //未知
  20. E_DISPATCH_COMMAND_READY = 1, //准备,待机
  21. E_DISPATCH_COMMAND_BUSY = 2, //工作正忙
  22. E_DISPATCH_COMMAND_DISCONNECT = 3, //断连
  23. E_DISPATCH_COMMAND_FAULT = 100, //故障
  24. };
  25. //调度指令, 格式和数据库的 command_queue 保持一致
  26. struct Dispatch_command_info
  27. {
  28. std::string m_car_number; //车牌号
  29. std::string m_primary_key; //唯一码
  30. int m_unit; //单元号, 1~3
  31. int m_queue_id; //排序的id, 从0开始递增
  32. int m_type; //指令类型, 0无效, 1存车, 2取车,
  33. int m_statu; //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  34. std::string m_space_info; //车位信息的DebugString, 默认没有, 存车要根据感测信息的车高去申请车位, 取车根据车牌号找车位
  35. parkspace_info m_parkspace_info_msg; //车位信息的proto格式
  36. std::string m_measure_info; //感测信息的DebugString, 里面自带车高, 小1.5 中1.7 大1.9,
  37. measure_info m_measure_info_msg; //感测信息的proto格式
  38. int m_export_id; //出入口id, 1~6
  39. int m_useless_distance; //空跑的路程,
  40. };
  41. //调度车位信息, 格式和数据库的 space 保持一致
  42. struct Dispatch_space_info
  43. {
  44. int m_id; //车位id
  45. int m_floor; //车位楼层
  46. int m_subID; //层内id
  47. float m_height; //车位高度, 小1.55 中1.75 大2.2,
  48. std::string m_car_number; //车牌号
  49. int m_unit; //单元号, 1~3
  50. int m_statu; //车位状态, 0可用, 1故障
  51. };
  52. //调度车辆信息, 格式和数据库的 vehicle 保持一致
  53. struct Dispatch_vehicle_info
  54. {
  55. std::string m_car_number; //车牌号
  56. std::string m_primary_key; //唯一码
  57. std::string m_actually_measure_info; //感测信息的DebugString, 里面自带车高, 小1.5 中1.7 大1.9,
  58. measure_info m_actually_measure_info_msg; //感测信息的proto格式
  59. };
  60. public:
  61. Dispatch_command();
  62. Dispatch_command(const Dispatch_command& other)= default;
  63. Dispatch_command& operator =(const Dispatch_command& other)= default;
  64. ~Dispatch_command();
  65. public://API functions
  66. //调度开始前, 向数据库发送请求的相关操作, 输入 穿梭机所在的楼层, 调度id 0~2, 空闲出口id, 如果不是0,就表示有空闲的出口
  67. Error_manager dispatch_request_to_sql(int plc_floor, int dispatch_id, int outlet_ready);
  68. //调度完成后, 向数据库发送答复的相关操作
  69. Error_manager dispatch_response_to_sql(Error_manager error);
  70. //调度 , 向数据库 重新分配车位,
  71. Error_manager dispatch_reallocate_to_sql(Common_data::Car_type reallocate_car_type, int outlet_ready);
  72. //检查出口是否空闲, 检查指令队列的取车完成的出口id是否存在, 不存在就是空闲,返回成功
  73. Error_manager check_export_id_is_ready(int export_id);
  74. public://get or set member variable
  75. protected://member functions
  76. //获取调度指令, 与数据库同步 command_queue
  77. Error_manager query_all_dispatch_command();
  78. //对调度指令进行排序, 选出最优解, 比较存车和取车
  79. Error_manager sort_dispatch_command_for_total();
  80. //对调度指令进行排序, 选出最优解, 只比较存车
  81. Error_manager sort_dispatch_command_for_park();
  82. //获取 指定车高 指定单元 的车位信息,用于车位分配, 找不到就会报错,
  83. Error_manager query_specify_height_unit_parkspace_info(int unit, float height, Dispatch_space_info & dispatch_space_info);
  84. //查询空闲车位最优解, 存车指令 根据调度指令最优解 获取 空闲车位最优解
  85. Error_manager query_dispatch_space_optimal();
  86. //查询空闲车位最优解, 存车指令 根据调度指令最优解 获取 空闲车位最优解
  87. Error_manager query_dispatch_space_optimal(Common_data::Car_type reallocate_car_type);
  88. //查询 取车的车位 取车指令 根据车牌号 查询对应的车位
  89. Error_manager query_dispatch_space_for_car_number();
  90. //查询 取车的车辆感测信息 取车指令 根据key 查询感测信息
  91. Error_manager query_dispatch_vehicle_for_primary_key();
  92. //更新 车位状态, 根据车位ID 修改车牌号即可,
  93. Error_manager update_parkspace_info_write_car_number();
  94. //更新 车位状态, 找到车牌号, 写NULL
  95. Error_manager update_parkspace_info_clear_car_number();
  96. //更新 指令队列, 根据车牌号 修改状态即可, //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  97. Error_manager update_command_queue_for_statu(int statu);
  98. //更新 指令队列, 根据车牌号 修改状态即可, //指令状态, 0排队中, 1正在工作, 2已完成, 3故障异常
  99. // Error_manager update_command_queue_for_statu(int statu, std::string error_description);
  100. //更新 指令队列, 根据车牌号 删除指令
  101. Error_manager delete_command_queue_for_statu();
  102. //制作存车表单
  103. Error_manager create_park_table();
  104. //制作取车表单
  105. Error_manager create_pick_table(int outlet_ready);
  106. //增加 车辆表, 存车指令 完成后添加车辆信息
  107. Error_manager insert_vehicle_for_car_number();
  108. //删除 车辆表, 取车指令 完成后删除车辆信息
  109. Error_manager delete_vehicle_for_car_number();
  110. protected://member variable
  111. public:
  112. Dispatch_command_status m_dispatch_command_status; //调度指令模块 的状态
  113. std::mutex m_lock; // 锁.
  114. int m_dispatch_id; //调度id, 0-2
  115. int m_unit; //单元号
  116. int m_device_floor; //穿梭机所在的楼层, 存车完在对应的车位楼层, 取车完在1楼
  117. int m_outlet_ready; //取车空闲出口id, 0表示没有出口, 1~6表示空闲出口
  118. std::map<std::string, Dispatch_command_info> m_dispatch_command_map; //调度指令map, 数据库的所有信息
  119. std::string m_car_number_optimal; //调度指令最优解
  120. Dispatch_space_info m_dispatch_space_info; //调度车位最优解
  121. Dispatch_vehicle_info m_dispatch_vehicle_info; //调度车位最优解
  122. Common_data::Dispatch_process_type m_dispatch_process_type ; //调度流程类型
  123. park_table m_park_table_msg; //停车表单
  124. pick_table m_pick_table_msg; //取车表单
  125. Common_data::Car_type m_car_type; //车的大小
  126. private:
  127. };
  128. #endif // __DISPATCH_COMMAND_HH__