parkspace_manager.cpp 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756
  1. /*
  2. * @Description: 车位分配算法模块,使用单例模式,接收外部请求并通过调用通信块接口发送反馈
  3. * @Author: yct
  4. * @Date: 2020-07-10 11:02:40
  5. * @LastEditTime: 2020-08-06 10:32:28
  6. * @LastEditors: yct
  7. */
  8. #include "parkspace_manager.h"
  9. #include "parkspace_communicator.h"
  10. Parkspace_manager::Parkspace_manager()
  11. {
  12. }
  13. Parkspace_manager::~Parkspace_manager()
  14. {
  15. parkspace_manager_uninit();
  16. }
  17. //初始化
  18. Error_manager Parkspace_manager::parkspace_manager_init(int threads_size)
  19. {
  20. // 初始化任务处理线程池
  21. m_thread_pool.thread_pool_init(threads_size);
  22. m_parkspace_manager_satus = eParkspace_manager_normal;
  23. return Error_code::SUCCESS;
  24. }
  25. //反初始化
  26. Error_manager Parkspace_manager::parkspace_manager_uninit()
  27. {
  28. m_thread_pool.thread_pool_uninit();
  29. m_parkspace_manager_satus = eParkspace_manager_unknown;
  30. return Error_code::SUCCESS;
  31. }
  32. //检查执行者的状态, 判断能否处理这条消息,
  33. Error_manager Parkspace_manager::check_status()
  34. {
  35. if(get_parkspace_manage_status() != eParkspace_manager_normal)
  36. {
  37. return Error_manager(Error_code::DB_MANAGER_STATUS_ERROR, Error_level::MAJOR_ERROR,
  38. " Parkspace_manager::check_executer error ");
  39. }
  40. return SUCCESS;
  41. }
  42. //处理消息的执行函数
  43. Error_manager Parkspace_manager::execute_msg(Communication_message* p_msg)
  44. {
  45. if ( p_msg == nullptr )
  46. {
  47. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  48. " POINTER IS NULL ");
  49. }
  50. switch ( p_msg->get_message_type() )
  51. {
  52. ///车位分配请求消息
  53. case Communication_message::eParkspace_allocation_request_msg:
  54. {
  55. message::Parkspace_allocation_request_msg request;
  56. bool result = request.ParseFromString(p_msg->get_message_buf());
  57. LOG(INFO)<<"allocation request, car license: "<<request.car_info().license();
  58. if(!result)
  59. {
  60. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_PARSE_ERROR, Error_level::MINOR_ERROR,
  61. " message::Parkspace_allocation_request_msg ParseFromString error ");
  62. }
  63. // std::cout<<"分配:"<<request.DebugString()<<std::endl;
  64. //往线程池添加执行任务, 之后会唤醒一个线程去执行他.
  65. m_thread_pool.enqueue(&Parkspace_manager::execute_for_allocate, this,
  66. request.car_info(), request.terminal_id(), request.command_key());
  67. return SUCCESS;
  68. }
  69. // 车位查询请求消息
  70. case Communication_message::eParkspace_search_request_msg:
  71. {
  72. message::Parkspace_search_request_msg request;
  73. bool result = request.ParseFromString(p_msg->get_message_buf());
  74. LOG(INFO)<<"search request, car license: "<<request.car_info().license();
  75. if(!result)
  76. {
  77. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_PARSE_ERROR, Error_level::MINOR_ERROR,
  78. " message::Parkspace_search_request_msg ParseFromString error ");
  79. }
  80. //往线程池添加执行任务, 之后会唤醒一个线程去执行他.
  81. // std::cout<<"查询:"<<request.DebugString()<<std::endl;
  82. m_thread_pool.enqueue(&Parkspace_manager::execute_for_search, this, request.car_info(), request.command_key());
  83. return SUCCESS;
  84. }
  85. // 车位释放请求消息
  86. case Communication_message::eParkspace_release_request_msg:
  87. {
  88. message::Parkspace_release_request_msg request;
  89. bool result = request.ParseFromString(p_msg->get_message_buf());
  90. LOG(INFO)<<"release request, parkspace id: "<<request.release_space_info().parkingspace_index_id();
  91. if(!result)
  92. {
  93. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_PARSE_ERROR, Error_level::MINOR_ERROR,
  94. " message::Parkspace_release_request_msg ParseFromString error ");
  95. }
  96. //往线程池添加执行任务, 之后会唤醒一个线程去执行他.
  97. // std::cout<<"释放:"<<request.DebugString()<<std::endl;
  98. m_thread_pool.enqueue(&Parkspace_manager::execute_for_release, this, request.release_space_info(), request.command_key());
  99. return SUCCESS;
  100. }
  101. // 车位手动更新请求消息
  102. case Communication_message::eParkspace_force_update_request_msg:
  103. {
  104. message::Parkspace_force_update_request_msg request;
  105. bool result = request.ParseFromString(p_msg->get_message_buf());
  106. LOG(INFO)<<"force update request, parkspace id: "<<request.update_space_info().parkingspace_index_id();
  107. if(!result)
  108. {
  109. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_PARSE_ERROR, Error_level::MINOR_ERROR,
  110. " message::Parkspace_force_update_request_msg ParseFromString error ");
  111. }
  112. //往线程池添加执行任务, 之后会唤醒一个线程去执行他.
  113. // std::cout<<"手动:"<<request.DebugString()<<std::endl;
  114. m_thread_pool.enqueue(&Parkspace_manager::execute_for_force_update, this, request.update_space_info(), request.command_key());
  115. return SUCCESS;
  116. }
  117. // 车位确认占用请求消息
  118. case Communication_message::eParkspace_confirm_alloc_request_msg:
  119. {
  120. message::Parkspace_confirm_alloc_request_msg request;
  121. bool result = request.ParseFromString(p_msg->get_message_buf());
  122. LOG(INFO)<<"confirm alloc request, parkspace id: "<<request.confirm_space_info().parkingspace_index_id();
  123. if(!result)
  124. {
  125. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_PARSE_ERROR, Error_level::MINOR_ERROR,
  126. " message::Parkspace_force_update_request_msg ParseFromString error ");
  127. }
  128. m_thread_pool.enqueue(&Parkspace_manager::execute_for_confirm_alloc, this, request.confirm_space_info(), request.command_key());
  129. return SUCCESS;
  130. }
  131. //车位数据刷新请求
  132. case Communication_message::eParkspace_refresh_request_msg:
  133. {
  134. return send_parkspace_data();
  135. }
  136. }
  137. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_MSG_REQUEST_TYPE_ERROR, Error_level::MINOR_ERROR,
  138. " fun error ");
  139. }
  140. Error_manager Parkspace_manager::encapsulating_heartbeat_messages()
  141. {
  142. //封装心跳消息
  143. Database_controller::Database_controller_status t_database_controller_status;
  144. Parkspace_manager::Parkspace_manager_satus t_parkspace_manager_satus;
  145. t_database_controller_status = Database_controller::get_instance_pointer()->get_database_controller_status();
  146. t_parkspace_manager_satus = Parkspace_manager::get_instance_pointer()->get_parkspace_manage_status();
  147. //车位信息消息赋值
  148. message::Parkspace_allocation_status_msg t_parkspace_status_msg;
  149. message::Base_info t_base_info;
  150. message::Error_manager t_error;
  151. t_base_info.set_msg_type(message::Message_type::eParkspace_allocation_status_msg);
  152. t_base_info.set_timeout_ms(5000);
  153. t_base_info.set_sender(message::Communicator::eParkspace);
  154. t_base_info.set_receiver(message::Communicator::eMain);
  155. t_error.set_error_code(0);
  156. t_parkspace_status_msg.mutable_base_info()->CopyFrom(t_base_info);
  157. t_parkspace_status_msg.mutable_error_manager()->CopyFrom(t_error);
  158. t_parkspace_status_msg.set_database_controller_status((message::Database_controller_status)t_database_controller_status);
  159. t_parkspace_status_msg.set_parkspace_manager_satus((message::Parkspace_manager_satus)t_parkspace_manager_satus);
  160. return Parkspace_communicator::get_instance_references().encapsulate_msg(t_parkspace_status_msg.SerializeAsString());
  161. }
  162. //判断是否为待机,如果已经准备好,则可以执行任务。
  163. bool Parkspace_manager::is_ready()
  164. {
  165. if ( m_parkspace_manager_satus == eParkspace_manager_normal && m_thread_pool.thread_is_full_load() == false )
  166. {
  167. return true;
  168. }
  169. else
  170. {
  171. return false;
  172. }
  173. }
  174. Parkspace_manager::Parkspace_manager_satus Parkspace_manager::get_parkspace_manage_status()
  175. {
  176. return m_parkspace_manager_satus;
  177. }
  178. // 检查车辆是否已存在,通常分配前调用
  179. bool Parkspace_manager::check_car_existence(std::string license)
  180. {
  181. message::Parkspace_info parkspaceInfo;
  182. //获取车辆状态
  183. Error_manager error=m_parkspace_operating_function.query_one_parkspace_with_license(license,parkspaceInfo);
  184. //如果车辆处于停车中或者已入库 则车辆已存在
  185. if(!parkspaceInfo.has_car_info())
  186. {
  187. return false;
  188. }
  189. return true;
  190. }
  191. Error_manager Parkspace_manager::send_parkspace_data()
  192. {
  193. message::Parkspace_allocation_data_msg all_parkspace_data;
  194. Error_manager t_error=m_parkspace_operating_function.get_all_parkspace_info(all_parkspace_data);
  195. if(t_error != SUCCESS)
  196. {
  197. return t_error;
  198. }
  199. message::Base_info t_base_info;
  200. message::Error_manager error;
  201. t_base_info.set_msg_type(message::Message_type::eParkspace_allocation_data_msg);
  202. t_base_info.set_timeout_ms(5000);
  203. t_base_info.set_sender(message::Communicator::eParkspace);
  204. t_base_info.set_receiver(message::Communicator::eMain);
  205. all_parkspace_data.mutable_base_info()->CopyFrom(t_base_info);
  206. error.set_error_code(0);
  207. all_parkspace_data.mutable_error_manager()->CopyFrom(error);
  208. return Parkspace_communicator::get_instance_references().encapsulate_msg(all_parkspace_data.SerializeAsString());
  209. }
  210. //找到一个最优车位---方案一
  211. Error_manager Parkspace_manager::query_the_optimal_parkspace_serverA(message::Parkspace_info &parkspace_info,message::Car_info car_info,int terminal_id)
  212. {
  213. //车辆高大于1550mm分在四楼以下,小于1550mm分在四楼以上
  214. /*
  215. * K=j%15
  216. * P=i%6
  217. * S=15*d-(j%15)*(2*d-1)+[6*d-(i%6)(2*d-1)]*W W>1
  218. */
  219. float time_min=0;
  220. int parkingspace_index_id=-1;
  221. //判断是否是左半库
  222. if ( terminal_id<=3 && terminal_id>=0 )
  223. {
  224. LOG(INFO) << " 左半库 车牌号:"<<car_info.license()<<" 车高:"<<car_info.car_height()<< this;
  225. //如果是小车 (低于1.55米属于小车)
  226. if ( car_info.car_height() <= MIN_CAR_HIGH )
  227. {
  228. //获取所有小型车位信息
  229. message::Parkspace_allocation_data_msg all_min_parkspace_data;
  230. Error_manager t_error = m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_min_parkspace_data, message::Parkspace_type::MIN_PARKINGSPACE);
  231. if (t_error != SUCCESS)
  232. {
  233. return t_error;
  234. }
  235. //遍历所有小型车位
  236. int i = 0;
  237. while (i < all_min_parkspace_data.parkspace_info_size())
  238. {
  239. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  240. //筛选出一号车库的小型车位(第一优先级)的空车位
  241. if (room_id %15 <= 7 && room_id %15 >= 1
  242. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  243. {
  244. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  245. float time = (terminal_id+2) * TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  246. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  247. (all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  248. if (time_min == 0)
  249. {
  250. time_min = time;
  251. parkingspace_index_id = i;
  252. }
  253. else
  254. {
  255. if ( time < time_min )
  256. {
  257. time_min = time;
  258. parkingspace_index_id = i;
  259. }
  260. }
  261. }
  262. ++i;
  263. }
  264. //判断小车车位(第一优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  265. if ( time_min!=0 && parkingspace_index_id!=-1 )
  266. {
  267. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  268. return Error_code::SUCCESS;
  269. }
  270. else
  271. {
  272. LOG(INFO) << " 小车车位未找到合适车位 "<< this;
  273. }
  274. }
  275. if ( car_info.car_height() <= MID_CAR_HIGH )
  276. {
  277. //第二优先级(中型车位)
  278. //获取中型车位
  279. message::Parkspace_allocation_data_msg all_mid_parkspace_data;
  280. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_mid_parkspace_data,message::Parkspace_type::MID_PARKINGSPACE);
  281. if(t_error != SUCCESS)
  282. {
  283. return t_error;
  284. }
  285. int i=0;
  286. while(i<all_mid_parkspace_data.parkspace_info_size())
  287. {
  288. //三楼的中型车位有单独的中跑车停车 且机械臂可以直接抓车到三楼
  289. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  290. if ( room_id >= 19 && room_id <= 22)
  291. {
  292. //只需计算端口到车位的距离
  293. // 三楼中型用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  294. float t_min=abs( room_id%15*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()-(terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  295. if ( time_min == 0 )
  296. {
  297. time_min=t_min;
  298. parkingspace_index_id=i;
  299. }
  300. else
  301. {
  302. if ( t_min<time_min )
  303. {
  304. time_min=t_min;
  305. parkingspace_index_id=i;
  306. }
  307. }
  308. }
  309. //如果是六楼的中型车位
  310. if ( room_id <= 67 && room_id >=61
  311. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  312. {
  313. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  314. float time=(terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  315. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  316. all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  317. if ( time_min == 0 )
  318. {
  319. time_min=time;
  320. parkingspace_index_id=i;
  321. }
  322. else
  323. {
  324. if ( time<time_min )
  325. {
  326. time_min=time;
  327. parkingspace_index_id=i;
  328. }
  329. }
  330. }
  331. ++i;
  332. }
  333. //判断中型车位(第二优先级)是否有找到合适的空车位 如果找到了 直接返回
  334. if ( time_min!=0 && parkingspace_index_id!=-1 )
  335. {
  336. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  337. return Error_code::SUCCESS;
  338. }
  339. else
  340. {
  341. LOG(INFO) << " 中车车位未找到合适车位 "<< this;
  342. }
  343. }
  344. if ( car_info.car_height() <= BIG_CAR_HIGH )
  345. {
  346. //第三优先级(大型车位)
  347. //获取大型车位
  348. message::Parkspace_allocation_data_msg all_big_parkspace_data;
  349. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_big_parkspace_data,message::Parkspace_type::BIG_PARKINGSPACE);
  350. if(t_error != SUCCESS)
  351. {
  352. return t_error;
  353. }
  354. int i=0;
  355. while(i<all_big_parkspace_data.parkspace_info_size())
  356. {
  357. int room_id=all_big_parkspace_data.parkspace_info(i).parkingspace_index_id();
  358. //筛选出一号车库的大型车位
  359. if ( room_id%15 <= 7 && room_id %15 >=1
  360. && all_big_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  361. {
  362. //如果是二楼车 则特殊处理
  363. if ( all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id() == 2 )
  364. {
  365. // 二楼用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  366. float t_min=abs( room_id%15*all_big_parkspace_data.parkspace_info(i).parkingspace_width() - (terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  367. if ( time_min == 0 )
  368. {
  369. time_min=t_min;
  370. parkingspace_index_id=i;
  371. }
  372. else
  373. {
  374. if ( t_min<time_min )
  375. {
  376. time_min=t_min;
  377. parkingspace_index_id=i;
  378. }
  379. }
  380. }
  381. else
  382. {
  383. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  384. float time=(terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  385. (all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_big_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  386. all_big_parkspace_data.parkspace_info(i).parkingspace_index_id()%15*all_big_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  387. if ( time_min == 0 )
  388. {
  389. time_min=time;
  390. parkingspace_index_id=i;
  391. }
  392. else
  393. {
  394. if ( time<time_min )
  395. {
  396. time_min=time;
  397. parkingspace_index_id=i;
  398. }
  399. }
  400. }
  401. }
  402. ++i;
  403. }
  404. //判断大型车位(第三优先级)是否有找到合适的空车位 如果找到了 直接返回
  405. if ( time_min!=0 && parkingspace_index_id!=-1 )
  406. {
  407. parkspace_info.CopyFrom(all_big_parkspace_data.parkspace_info(parkingspace_index_id));
  408. return Error_code::SUCCESS;
  409. }
  410. else
  411. {
  412. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_ALLOCATE_FAILED, Error_level::MINOR_ERROR,
  413. " query_the_optimal_parkspace_serverA error ");
  414. }
  415. }
  416. }
  417. //判断是否是右半库
  418. else if(terminal_id<=6 && terminal_id>=4)
  419. {
  420. //如果是小车 (低于1.55米属于小车)
  421. if ( car_info.car_height() <= MIN_CAR_HIGH )
  422. {
  423. //获取所有小型车位信息
  424. message::Parkspace_allocation_data_msg all_min_parkspace_data;
  425. Error_manager t_error = m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_min_parkspace_data, message::Parkspace_type::MIN_PARKINGSPACE);
  426. if (t_error != SUCCESS)
  427. {
  428. return t_error;
  429. }
  430. //遍历所有小型车位
  431. int i = 0;
  432. while (i < all_min_parkspace_data.parkspace_info_size())
  433. {
  434. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  435. //筛选出一号车库的小型车位(第一优先级)的空车位
  436. if (room_id <= 165 && room_id >= 53
  437. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  438. {
  439. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  440. float time = (6-terminal_id+2)* TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  441. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  442. ( (15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15)==15?0:(15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) ) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  443. if (time_min == 0)
  444. {
  445. time_min = time;
  446. parkingspace_index_id = i;
  447. }
  448. else
  449. {
  450. if ( time < time_min )
  451. {
  452. time_min = time;
  453. parkingspace_index_id = i;
  454. }
  455. }
  456. }
  457. ++i;
  458. }
  459. //判断小车车位(第一优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  460. if ( time_min!=0 && parkingspace_index_id!=-1 )
  461. {
  462. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  463. return Error_code::SUCCESS;
  464. }
  465. }
  466. if ( car_info.car_height() <= MID_CAR_HIGH )
  467. {
  468. //第二优先级(中型车位)
  469. //获取中型车位
  470. message::Parkspace_allocation_data_msg all_mid_parkspace_data;
  471. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_mid_parkspace_data,message::Parkspace_type::MID_PARKINGSPACE);
  472. if(t_error != SUCCESS)
  473. {
  474. return t_error;
  475. }
  476. int i=0;
  477. while(i<all_mid_parkspace_data.parkspace_info_size())
  478. {
  479. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  480. //三楼的中型车位有单独的中跑车停车 且机械臂可以直接抓车到三楼
  481. if ( room_id >= 23 && room_id <= 27 )
  482. {
  483. //只需计算端口到车位的距离
  484. // 三楼中型车位用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  485. float t_min=abs( ((15-room_id%15)==15?0:(15-room_id%15))*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()-(6-terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  486. if ( time_min == 0 )
  487. {
  488. time_min=t_min;
  489. parkingspace_index_id=i;
  490. }
  491. else
  492. {
  493. if ( t_min<time_min )
  494. {
  495. time_min=t_min;
  496. parkingspace_index_id=i;
  497. }
  498. }
  499. }
  500. if ( room_id <= 75 && room_id >= 68
  501. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  502. {
  503. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  504. float time=(6-terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  505. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  506. ( ((15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15) ==15?0:(15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15)) )*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  507. if ( time_min == 0 )
  508. {
  509. time_min=time;
  510. parkingspace_index_id=i;
  511. }
  512. else
  513. {
  514. if ( time<time_min )
  515. {
  516. time_min=time;
  517. parkingspace_index_id=i;
  518. }
  519. }
  520. }
  521. ++i;
  522. }
  523. //判断中型车位(第二优先级)是否有找到合适的空车位 如果找到了 直接返回
  524. if ( time_min!=0 && parkingspace_index_id!=-1 )
  525. {
  526. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  527. return Error_code::SUCCESS;
  528. }
  529. }
  530. if ( car_info.car_height() <= BIG_CAR_HIGH )
  531. {
  532. //第三优先级(大型车位)
  533. //获取大型车位
  534. message::Parkspace_allocation_data_msg all_big_parkspace_data;
  535. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_big_parkspace_data,message::Parkspace_type::BIG_PARKINGSPACE);
  536. if(t_error != SUCCESS)
  537. {
  538. return t_error;
  539. }
  540. int i=0;
  541. while(i<all_big_parkspace_data.parkspace_info_size())
  542. {
  543. int room_id=all_big_parkspace_data.parkspace_info(i).parkingspace_index_id();
  544. //筛选出二号车库的大型车位的空车位
  545. if ( room_id %15 >=8 && room_id %15 <=14 || room_id %15 == 0
  546. && all_big_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  547. {
  548. //如果是二楼车 则特殊处理
  549. if ( all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id() == 2 )
  550. {
  551. // 二楼用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  552. float t_min=abs( ((15-room_id%15)==15?0:(15-room_id%15))*all_big_parkspace_data.parkspace_info(i).parkingspace_width()-(6-terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  553. if ( time_min == 0 )
  554. {
  555. time_min=t_min;
  556. parkingspace_index_id=i;
  557. }
  558. else
  559. {
  560. if ( t_min<time_min )
  561. {
  562. time_min=t_min;
  563. parkingspace_index_id=i;
  564. }
  565. }
  566. }
  567. else
  568. {
  569. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  570. float time=(6-terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  571. (all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_big_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  572. ( ((15-all_big_parkspace_data.parkspace_info(i).parkingspace_index_id()%15) ==15?0:(15-all_big_parkspace_data.parkspace_info(i).parkingspace_index_id()%15)) )*all_big_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  573. if ( time_min == 0 )
  574. {
  575. time_min=time;
  576. parkingspace_index_id=i;
  577. }
  578. else
  579. {
  580. if ( time<time_min )
  581. {
  582. time_min=time;
  583. parkingspace_index_id=i;
  584. }
  585. }
  586. }
  587. }
  588. ++i;
  589. }
  590. //判断大型车位(第三优先级)是否有找到合适的空车位 如果找到了 直接返回
  591. if ( time_min!=0 && parkingspace_index_id!=-1 )
  592. {
  593. parkspace_info.CopyFrom(all_big_parkspace_data.parkspace_info(parkingspace_index_id));
  594. return Error_code::SUCCESS;
  595. }
  596. else
  597. {
  598. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_ALLOCATE_FAILED, Error_level::MINOR_ERROR,
  599. " query_the_optimal_parkspace_serverA error ");
  600. }
  601. }
  602. }
  603. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  604. "query_the_optimal_parkspace_serverA error ");
  605. }
  606. //找到一个最优车位---方案二
  607. //找左侧车位
  608. Error_manager Parkspace_manager::query_the_optimal_parkspace_serverB1(message::Parkspace_info &parkspace_info,message::Car_info car_info,int terminal_id)
  609. {
  610. //车辆高大于1550mm分在四楼以下,小于1550mm分在四楼以上
  611. /*
  612. * K=j%15
  613. * P=i%6
  614. * S=15*d-(j%15)*(2*d-1)+[6*d-(i%6)(2*d-1)]*W W>1
  615. */
  616. float time_min=0;
  617. int parkingspace_index_id=-1;
  618. //找左侧车位
  619. //如果是小车 (低于1.55米属于小车)
  620. if ( car_info.car_height() <= MIN_CAR_HIGH )
  621. {
  622. //获取所有小型车位信息
  623. message::Parkspace_allocation_data_msg all_min_parkspace_data;
  624. Error_manager t_error = m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_min_parkspace_data, message::Parkspace_type::MIN_PARKINGSPACE);
  625. if (t_error != SUCCESS)
  626. {
  627. return t_error;
  628. }
  629. //遍历所有小型车位
  630. int i = 0;
  631. while (i < all_min_parkspace_data.parkspace_info_size())
  632. {
  633. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  634. //筛选出小型车位的中间部分(第一优先级)的空车位
  635. if (room_id % 15 <= 7 && room_id % 15 >= 4
  636. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  637. {
  638. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  639. float time = (terminal_id+2) * TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  640. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  641. (all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  642. if (time_min == 0)
  643. {
  644. time_min = time;
  645. parkingspace_index_id = i;
  646. }
  647. else
  648. {
  649. if ( time<time_min )
  650. {
  651. time_min=time;
  652. parkingspace_index_id=i;
  653. }
  654. }
  655. }
  656. ++i;
  657. }
  658. //判断小车车位中间部分(第一优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  659. if ( time_min!=0 && parkingspace_index_id!=-1 )
  660. {
  661. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  662. parkspace_info.set_path_estimate_time(time_min);
  663. parkspace_info.set_parkspace_path(message::LEFT_PATH);
  664. return Error_code::SUCCESS;
  665. }
  666. else
  667. {
  668. //如果没找到则找小车车位第二优先级 (侧边)
  669. int i = 0;
  670. while (i < all_min_parkspace_data.parkspace_info_size())
  671. {
  672. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  673. if (room_id % 15 <= 3 && room_id % 15 >= 1
  674. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  675. {
  676. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  677. float time = (terminal_id+2) * TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  678. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  679. (all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  680. if (time_min == 0)
  681. {
  682. time_min = time;
  683. parkingspace_index_id = i;
  684. }
  685. else
  686. {
  687. if ( time < time_min )
  688. {
  689. time_min = time;
  690. parkingspace_index_id = i;
  691. }
  692. }
  693. }
  694. ++i;
  695. }
  696. //判断小车车位侧边部分(第二优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  697. if ( time_min!=0 && parkingspace_index_id!=-1 )
  698. {
  699. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  700. parkspace_info.set_path_estimate_time(time_min);
  701. parkspace_info.set_parkspace_path(message::LEFT_PATH);
  702. return Error_code::SUCCESS;
  703. }
  704. }
  705. }
  706. if ( car_info.car_height() <= MID_CAR_HIGH )
  707. {
  708. //找中型车位
  709. //获取中型车位
  710. message::Parkspace_allocation_data_msg all_mid_parkspace_data;
  711. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_mid_parkspace_data,message::Parkspace_type::MID_PARKINGSPACE);
  712. if(t_error != SUCCESS)
  713. {
  714. return t_error;
  715. }
  716. int i=0;
  717. while(i<all_mid_parkspace_data.parkspace_info_size())
  718. {
  719. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  720. //如果是六楼的中型车位的中间部分(第一优先级)
  721. if ( room_id >=64 && room_id <= 67
  722. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  723. {
  724. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  725. float time=(terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  726. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  727. (all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15)*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  728. if ( time_min == 0 )
  729. {
  730. time_min=time;
  731. parkingspace_index_id=i;
  732. }
  733. else
  734. {
  735. if ( time<time_min )
  736. {
  737. time_min=time;
  738. parkingspace_index_id=i;
  739. }
  740. }
  741. }
  742. ++i;
  743. }
  744. //判断中型车位的中间部分(第一优先级)是否有找到合适的空车位 如果找到了 直接返回
  745. if ( time_min!=0 && parkingspace_index_id!=-1 )
  746. {
  747. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  748. parkspace_info.set_path_estimate_time(time_min);
  749. parkspace_info.set_parkspace_path(message::LEFT_PATH);
  750. return Error_code::SUCCESS;
  751. }
  752. else
  753. {
  754. //如果没找到则找侧边中型车位(第二优先级)
  755. int i=0;
  756. while(i<all_mid_parkspace_data.parkspace_info_size())
  757. {
  758. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  759. //如果是六楼的中型车位的侧边(第二优先级)
  760. if ( room_id >=61 && room_id <= 63
  761. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  762. {
  763. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  764. float time=(terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  765. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  766. all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  767. if ( time_min == 0 )
  768. {
  769. time_min=time;
  770. parkingspace_index_id=i;
  771. }
  772. else
  773. {
  774. if ( time<time_min )
  775. {
  776. time_min=time;
  777. parkingspace_index_id=i;
  778. }
  779. }
  780. }
  781. ++i;
  782. }
  783. //判断中型车位侧边(第二优先级)是否有找到合适的空车位 如果找到了 直接返回
  784. if ( time_min!=0 && parkingspace_index_id!=-1 )
  785. {
  786. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  787. parkspace_info.set_path_estimate_time(time_min);
  788. parkspace_info.set_parkspace_path(message::LEFT_PATH);
  789. return Error_code::SUCCESS;
  790. }
  791. }
  792. }
  793. if ( car_info.car_height() <= BIG_CAR_HIGH )
  794. {
  795. //找大型车位
  796. //获取大型车位
  797. message::Parkspace_allocation_data_msg all_big_parkspace_data;
  798. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_big_parkspace_data,message::Parkspace_type::BIG_PARKINGSPACE);
  799. if(t_error != SUCCESS)
  800. {
  801. return t_error;
  802. }
  803. int i=0;
  804. while(i<all_big_parkspace_data.parkspace_info_size())
  805. {
  806. int room_id=all_big_parkspace_data.parkspace_info(i).parkingspace_index_id();
  807. //筛选出一号车库的小型车位的靠近电梯的左侧三排(第二优先级)的空车位
  808. if ( room_id %15 == 1 || room_id %15 == 2 || room_id %15 == 3 || room_id>=34 && room_id<=37
  809. && all_big_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  810. {
  811. //如果是二楼车 则特殊处理
  812. if ( all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id() == 2 )
  813. {
  814. // 二楼用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  815. float t_min=abs( room_id%15*all_big_parkspace_data.parkspace_info(i).parkingspace_width()-(terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  816. if ( time_min == 0 )
  817. {
  818. time_min=t_min;
  819. parkingspace_index_id=i;
  820. }
  821. else
  822. {
  823. if ( t_min<time_min )
  824. {
  825. time_min=t_min;
  826. parkingspace_index_id=i;
  827. }
  828. }
  829. }
  830. else
  831. {
  832. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  833. float time=(terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  834. (all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_big_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  835. all_big_parkspace_data.parkspace_info(i).parkingspace_index_id()%15*all_big_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  836. if ( time_min == 0 )
  837. {
  838. time_min=time;
  839. parkingspace_index_id=i;
  840. }
  841. else
  842. {
  843. if ( time<time_min )
  844. {
  845. time_min=time;
  846. parkingspace_index_id=i;
  847. }
  848. }
  849. }
  850. }
  851. ++i;
  852. }
  853. //判断大型车位是否有找到合适的空车位 如果找到了 直接返回
  854. if ( time_min!=0 && parkingspace_index_id!=-1 )
  855. {
  856. parkspace_info.CopyFrom(all_big_parkspace_data.parkspace_info(parkingspace_index_id));
  857. parkspace_info.set_path_estimate_time(time_min);
  858. parkspace_info.set_parkspace_path(message::LEFT_PATH);
  859. return Error_code::SUCCESS;
  860. }
  861. else
  862. {
  863. //如果没找到则代表左侧没找到合适车位
  864. parkspace_info.set_parkingspace_index_id(-1);
  865. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_ALLOCATE_FAILED, Error_level::NEGLIGIBLE_ERROR,
  866. "query_the_optimal_parkspace_serverB1 error ");
  867. }
  868. }
  869. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  870. " query_the_optimal_parkspace_serverB1 error ");
  871. }
  872. //找右侧车位
  873. Error_manager Parkspace_manager::query_the_optimal_parkspace_serverB2(message::Parkspace_info &parkspace_info,message::Car_info car_info,int terminal_id)
  874. {
  875. //车辆高大于1550mm分在四楼以下,小于1550mm分在四楼以上
  876. /*
  877. * K=j%15
  878. * P=i%6
  879. * S=15*d-(j%15)*(2*d-1)+[6*d-(i%6)(2*d-1)]*W W>1
  880. */
  881. float time_min=0;
  882. int parkingspace_index_id=-1;
  883. //找右侧车位
  884. //如果是小车 (低于1.55米属于小车)
  885. if ( car_info.car_height() <= MIN_CAR_HIGH )
  886. {
  887. //获取所有小型车位信息
  888. message::Parkspace_allocation_data_msg all_min_parkspace_data;
  889. Error_manager t_error = m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_min_parkspace_data, message::Parkspace_type::MIN_PARKINGSPACE);
  890. if (t_error != SUCCESS)
  891. {
  892. return t_error;
  893. }
  894. //遍历所有小型车位
  895. int i = 0;
  896. while (i < all_min_parkspace_data.parkspace_info_size())
  897. {
  898. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  899. //筛选出小型车位的中间部分(第一优先级)的空车位
  900. if (room_id % 15 >= 8 && room_id % 15 <= 12
  901. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  902. {
  903. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  904. float time = (6-terminal_id+2) * TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  905. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  906. ( (15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15)==15?0:(15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) ) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  907. if (time_min == 0)
  908. {
  909. time_min = time;
  910. parkingspace_index_id = i;
  911. }
  912. else
  913. {
  914. if ( time<time_min )
  915. {
  916. time_min=time;
  917. parkingspace_index_id=i;
  918. }
  919. }
  920. }
  921. ++i;
  922. }
  923. //判断小车车位中间部分(第一优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  924. if ( time_min!=0 && parkingspace_index_id!=-1 )
  925. {
  926. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  927. return Error_code::SUCCESS;
  928. }
  929. else
  930. {
  931. //如果没找到则找小车车位第二优先级 (侧边)
  932. int i = 0;
  933. while (i < all_min_parkspace_data.parkspace_info_size())
  934. {
  935. int room_id=all_min_parkspace_data.parkspace_info(i).parkingspace_index_id();
  936. //筛选出一号车库的小型车位的中间部分(第一优先级)的空车位
  937. if (room_id % 15 == 13 || room_id % 15 == 14 || room_id % 15 == 0
  938. && all_min_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty)
  939. {
  940. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  941. float time = (6-terminal_id+2) * TERMINAL_SPACING / MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  942. (all_min_parkspace_data.parkspace_info(i).parkingspace_floor_id() - 2) *all_min_parkspace_data.parkspace_info(i).parkingspace_height() /THE_ELEVATOR_SPEED +ELEVATOR_MOVEMENT_TIME +
  943. ( (15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15)==15?0:(15-all_min_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) ) *all_min_parkspace_data.parkspace_info(i).parkingspace_width() / MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  944. if (time_min == 0)
  945. {
  946. time_min = time;
  947. parkingspace_index_id = i;
  948. }
  949. else
  950. {
  951. if ( time < time_min )
  952. {
  953. time_min = time;
  954. parkingspace_index_id = i;
  955. }
  956. }
  957. }
  958. ++i;
  959. }
  960. //判断小车车位侧边部分(第二优先级)是否有找到合适的空车位 如果找到了 则不需要继续比较 直接返回
  961. if ( time_min!=0 && parkingspace_index_id!=-1 )
  962. {
  963. parkspace_info.CopyFrom(all_min_parkspace_data.parkspace_info(parkingspace_index_id));
  964. parkspace_info.set_path_estimate_time(time_min);
  965. parkspace_info.set_parkspace_path(message::RIGHT_PATH);
  966. return Error_code::SUCCESS;
  967. }
  968. }
  969. }
  970. if ( car_info.car_height() <= MID_CAR_HIGH )
  971. {
  972. //找中型车位
  973. //获取中型车位
  974. message::Parkspace_allocation_data_msg all_mid_parkspace_data;
  975. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_mid_parkspace_data,message::Parkspace_type::MID_PARKINGSPACE);
  976. if(t_error != SUCCESS)
  977. {
  978. return t_error;
  979. }
  980. int i=0;
  981. while(i<all_mid_parkspace_data.parkspace_info_size())
  982. {
  983. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  984. //如果是六楼的中型车位的中间部分(第一优先级)
  985. if ( room_id >= 68 && room_id <= 72
  986. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  987. {
  988. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  989. float time=(6-terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  990. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  991. ( ((15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15) ==15?0:(15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15)) )*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  992. if ( time_min == 0 )
  993. {
  994. time_min=time;
  995. parkingspace_index_id=i;
  996. }
  997. else
  998. {
  999. if ( time<time_min )
  1000. {
  1001. time_min=time;
  1002. parkingspace_index_id=i;
  1003. }
  1004. }
  1005. }
  1006. ++i;
  1007. }
  1008. //判断中型车位的中间部分(第一优先级)是否有找到合适的空车位 如果找到了 直接返回
  1009. if ( time_min!=0 && parkingspace_index_id!=-1 )
  1010. {
  1011. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  1012. parkspace_info.set_path_estimate_time(time_min);
  1013. parkspace_info.set_parkspace_path(message::RIGHT_PATH);
  1014. return Error_code::SUCCESS;
  1015. }
  1016. else
  1017. {
  1018. //如果没找到则找侧边中型车位(第二优先级)
  1019. int i=0;
  1020. while(i<all_mid_parkspace_data.parkspace_info_size())
  1021. {
  1022. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  1023. //如果是六楼的中型车位的侧边(第二优先级)
  1024. if ( room_id >=73 && room_id <= 75
  1025. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  1026. {
  1027. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  1028. float time=(6-terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  1029. (all_mid_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_mid_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  1030. ( ((15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15) ==15?0:(15-all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id()%15)) )*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  1031. if ( time_min == 0 )
  1032. {
  1033. time_min=time;
  1034. parkingspace_index_id=i;
  1035. }
  1036. else
  1037. {
  1038. if ( time<time_min )
  1039. {
  1040. time_min=time;
  1041. parkingspace_index_id=i;
  1042. }
  1043. }
  1044. }
  1045. ++i;
  1046. }
  1047. //判断中型车位侧边(第二优先级)是否有找到合适的空车位 如果找到了 直接返回
  1048. if ( time_min!=0 && parkingspace_index_id!=-1 )
  1049. {
  1050. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  1051. parkspace_info.set_path_estimate_time(time_min);
  1052. parkspace_info.set_parkspace_path(message::RIGHT_PATH);
  1053. return Error_code::SUCCESS;
  1054. }
  1055. }
  1056. }
  1057. if ( car_info.car_height() <= BIG_CAR_HIGH )
  1058. {
  1059. //找大型车位
  1060. //获取大型车位
  1061. message::Parkspace_allocation_data_msg all_big_parkspace_data;
  1062. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_big_parkspace_data,message::Parkspace_type::BIG_PARKINGSPACE);
  1063. if(t_error != SUCCESS)
  1064. {
  1065. return t_error;
  1066. }
  1067. int i=0;
  1068. while(i<all_big_parkspace_data.parkspace_info_size())
  1069. {
  1070. int room_id=all_big_parkspace_data.parkspace_info(i).parkingspace_index_id();
  1071. //筛选出大型车位的靠近电梯的右侧三排(第二优先级)的空车位
  1072. if ( room_id %15 == 13 || room_id %15 == 14 || room_id %15 == 0|| room_id>=38 && room_id<=42
  1073. && all_big_parkspace_data.parkspace_info(i).parkingspace_status() == message::Parkspace_status::eParkspace_empty )
  1074. {
  1075. //如果是二楼车 则特殊处理
  1076. if ( all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id() == 2 )
  1077. {
  1078. // 二楼用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  1079. float t_min=abs( ((15-room_id%15)==15?0:(15-room_id%15))*all_big_parkspace_data.parkspace_info(i).parkingspace_width()-(6-terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  1080. if ( time_min == 0 )
  1081. {
  1082. time_min=t_min;
  1083. parkingspace_index_id=i;
  1084. }
  1085. else
  1086. {
  1087. if ( t_min<time_min )
  1088. {
  1089. time_min=t_min;
  1090. parkingspace_index_id=i;
  1091. }
  1092. }
  1093. }
  1094. else
  1095. {
  1096. //用时=目标终端到电梯口的距离/中跑车速度+(目标车位楼层-2)*楼层高度/电梯速度+电梯口到目标车位的距离/中跑车速度
  1097. float time=(6-terminal_id+2)*TERMINAL_SPACING/MEDIUM_CAR_SPEED + DOWNSTAIRS_SPORTS_TIME +
  1098. (all_big_parkspace_data.parkspace_info(i).parkingspace_floor_id()-2)*all_big_parkspace_data.parkspace_info(i).parkingspace_height()/THE_ELEVATOR_SPEED + ELEVATOR_MOVEMENT_TIME +
  1099. ( (15-all_big_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15)==15?0:(15-all_big_parkspace_data.parkspace_info(i).parkingspace_index_id() % 15) )*all_big_parkspace_data.parkspace_info(i).parkingspace_width()/MEDIUM_CAR_SPEED + UPSTAIRS_SPORTS_TIME;
  1100. if ( time_min == 0 )
  1101. {
  1102. time_min=time;
  1103. parkingspace_index_id=i;
  1104. }
  1105. else
  1106. {
  1107. if ( time<time_min )
  1108. {
  1109. time_min=time;
  1110. parkingspace_index_id=i;
  1111. }
  1112. }
  1113. }
  1114. }
  1115. ++i;
  1116. }
  1117. //判断大型车位是否有找到合适的空车位 如果找到了 直接返回
  1118. if ( time_min!=0 && parkingspace_index_id!=-1 )
  1119. {
  1120. parkspace_info.CopyFrom(all_big_parkspace_data.parkspace_info(parkingspace_index_id));
  1121. parkspace_info.set_path_estimate_time(time_min);
  1122. parkspace_info.set_parkspace_path(message::RIGHT_PATH);
  1123. return Error_code::SUCCESS;
  1124. }
  1125. else
  1126. {
  1127. //如果没找到则代表右侧没找到合适车位
  1128. parkspace_info.set_parkingspace_index_id(-1);
  1129. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_ALLOCATE_FAILED, Error_level::NEGLIGIBLE_ERROR,
  1130. "query_the_optimal_parkspace_serverB2 error ");
  1131. }
  1132. }
  1133. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  1134. " query_the_optimal_parkspace_serverB2 error ");
  1135. }
  1136. //找缓存区车位
  1137. Error_manager Parkspace_manager::query_the_optimal_parkspace_serverB3(message::Parkspace_info &parkspace_info,message::Car_info car_info,int terminal_id)
  1138. {
  1139. //车辆高大于1550mm分在四楼以下,小于1550mm分在四楼以上
  1140. /*
  1141. * K=j%15
  1142. * P=i%6
  1143. * S=15*d-(j%15)*(2*d-1)+[6*d-(i%6)(2*d-1)]*W W>1
  1144. */
  1145. float time_min=0;
  1146. int parkingspace_index_id=-1;
  1147. //找缓存区车位 缓冲区只有中型车位和大型车位
  1148. if ( car_info.car_height() <= MID_CAR_HIGH )
  1149. {
  1150. message::Parkspace_allocation_data_msg all_mid_parkspace_data;
  1151. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_mid_parkspace_data,message::Parkspace_type::MID_PARKINGSPACE);
  1152. if(t_error != SUCCESS)
  1153. {
  1154. return t_error;
  1155. }
  1156. int i=0;
  1157. while (i < all_mid_parkspace_data.parkspace_info_size())
  1158. {
  1159. //筛选中型车位缓冲区
  1160. int room_id=all_mid_parkspace_data.parkspace_info(i).parkingspace_index_id();
  1161. if ( room_id >= 19 && room_id <= 27
  1162. && all_mid_parkspace_data.parkspace_info(i).parkingspace_status() == message::eParkspace_empty)
  1163. {
  1164. //只需计算端口到车位的距离
  1165. // 三楼中型用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  1166. float t_min=abs( room_id%15*all_mid_parkspace_data.parkspace_info(i).parkingspace_width()-(terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  1167. if ( time_min == 0 )
  1168. {
  1169. time_min=t_min;
  1170. parkingspace_index_id=i;
  1171. }
  1172. else
  1173. {
  1174. if ( t_min<time_min )
  1175. {
  1176. time_min=t_min;
  1177. parkingspace_index_id=i;
  1178. }
  1179. }
  1180. }
  1181. ++i;
  1182. }
  1183. //判断缓冲区的中型车位是否有找到合适的空车位 如果找到了 直接返回
  1184. if ( time_min!=0 && parkingspace_index_id!=-1 )
  1185. {
  1186. parkspace_info.CopyFrom(all_mid_parkspace_data.parkspace_info(parkingspace_index_id));
  1187. parkspace_info.set_path_estimate_time(time_min);
  1188. parkspace_info.set_parkspace_path(message::TEMPORARY_CACHE_PATH);
  1189. return Error_code::SUCCESS;
  1190. }
  1191. }
  1192. if( car_info.car_height() <= BIG_CAR_HIGH )
  1193. {
  1194. message::Parkspace_allocation_data_msg all_big_parkspace_data;
  1195. Error_manager t_error=m_parkspace_operating_function.get_specify_the_type_parkspace_info(all_big_parkspace_data,message::Parkspace_type::BIG_PARKINGSPACE);
  1196. if(t_error != SUCCESS)
  1197. {
  1198. return t_error;
  1199. }
  1200. int i=0;
  1201. while (i < all_big_parkspace_data.parkspace_info_size())
  1202. {
  1203. //筛选中型车位缓冲区
  1204. int room_id=all_big_parkspace_data.parkspace_info(i).parkingspace_index_id();
  1205. if ( room_id >= 4 && room_id <= 12
  1206. && all_big_parkspace_data.parkspace_info(i).parkingspace_status() == message::eParkspace_empty)
  1207. {
  1208. //只需计算端口到车位的距离
  1209. // 二楼中型用时=| 目标车位到电梯的距离 - 终端到电梯的距离 | / 中跑车速度
  1210. float t_min=abs( room_id%15*all_big_parkspace_data.parkspace_info(i).parkingspace_width()-(terminal_id+2)*TERMINAL_SPACING )/MEDIUM_CAR_SPEED+DOWNSTAIRS_SPORTS_TIME;
  1211. if ( time_min == 0 )
  1212. {
  1213. time_min=t_min;
  1214. parkingspace_index_id=i;
  1215. }
  1216. else
  1217. {
  1218. if ( t_min<time_min )
  1219. {
  1220. time_min=t_min;
  1221. parkingspace_index_id=i;
  1222. }
  1223. }
  1224. }
  1225. }
  1226. //判断缓冲区的中型车位是否有找到合适的空车位 如果找到了 直接返回
  1227. if ( time_min!=0 && parkingspace_index_id!=-1 )
  1228. {
  1229. parkspace_info.CopyFrom(all_big_parkspace_data.parkspace_info(parkingspace_index_id));
  1230. parkspace_info.set_path_estimate_time(time_min);
  1231. parkspace_info.set_parkspace_path(message::TEMPORARY_CACHE_PATH);
  1232. return Error_code::SUCCESS;
  1233. }
  1234. else
  1235. {
  1236. //如果没找到则代表缓冲区没找到合适车位
  1237. parkspace_info.set_parkingspace_index_id(-1);
  1238. return Error_manager(Error_code::PARKSPACE_ALLOCATOR_ALLOCATE_FAILED, Error_level::NEGLIGIBLE_ERROR,
  1239. "query_the_optimal_parkspace_serverB2 error ");
  1240. }
  1241. }
  1242. return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
  1243. " query_the_optimal_parkspace_serverB3 error ");
  1244. }
  1245. //分配车位线程函数
  1246. void Parkspace_manager::execute_for_allocate(message::Car_info car_info, int terminal_id, std::string command_key)
  1247. {
  1248. LOG(INFO) << "分配车位 "<<"牌号:"<<car_info.license()<<" command_key="<<command_key; //huli printf command_key
  1249. //根据请求的信息反馈分配的车位,并封装发送
  1250. message::Parkspace_allocation_response_msg response_msg;
  1251. message::Base_info t_response_header;
  1252. t_response_header.set_msg_type(message::Message_type::eParkspace_allocation_response_msg);
  1253. t_response_header.set_timeout_ms(1000);
  1254. t_response_header.set_sender(message::Communicator::eParkspace);
  1255. t_response_header.set_receiver(message::Communicator::eMain);
  1256. message::Error_manager t_error;
  1257. message::Parkspace_info t_allocated_space;
  1258. Error_manager error;
  1259. //分配之前查询车辆是否已经存在
  1260. if(check_car_existence(car_info.license()))
  1261. {
  1262. t_error.set_error_code(PARKSPACE_ALLOCATOR_CAR_ALREADY_EXIST);
  1263. t_error.set_error_level(message::Error_level::MAJOR_ERROR);
  1264. t_error.set_error_description("车辆已存在");
  1265. LOG(ERROR) << car_info.license()<<" 车辆已存在";
  1266. }
  1267. else
  1268. {
  1269. m_parkspace_lock.lock();
  1270. // 如果车辆不存在 则找到一个最优车位(方案A)----车库分为两个独立部分,左库和右库如果1~3号终端来车 则在左库分配车位,4~号终端来车 则在右库分配车位
  1271. // error=query_the_optimal_parkspace_serverA(t_allocated_space,car_info,terminal_id);
  1272. // 如果车辆不存在 则找到一个最优车位(方案B)----分配三个车位 左边分配一个 右边分配一个 缓冲区分配一个 最后使用那个由调度决定
  1273. message::Parkspace_info t_allocated_space_left;
  1274. message::Parkspace_info t_allocated_space_rigth;
  1275. message::Parkspace_info t_allocated_space_temporary;
  1276. //
  1277. error=query_the_optimal_parkspace_serverB1(t_allocated_space_left,car_info,terminal_id);
  1278. if ( error != Error_code::SUCCESS )
  1279. {
  1280. t_error.set_error_code(error.get_error_code());
  1281. t_error.set_error_level((message::Error_level)error.get_error_level());
  1282. t_error.set_error_description(error.get_error_description());
  1283. LOG(ERROR) << car_info.license()<<" 获取左侧车位失败 "<<error.to_string();
  1284. }
  1285. LOG(INFO) << " 左侧车位ID: "<<t_allocated_space_left.parkingspace_index_id();
  1286. error=query_the_optimal_parkspace_serverB2(t_allocated_space_rigth,car_info,terminal_id);
  1287. if ( error != Error_code::SUCCESS )
  1288. {
  1289. t_error.set_error_code(error.get_error_code());
  1290. t_error.set_error_level((message::Error_level)error.get_error_level());
  1291. t_error.set_error_description(error.get_error_description());
  1292. LOG(ERROR) << car_info.license()<<" 获取右侧车位失败 "<<error.to_string();
  1293. }
  1294. LOG(INFO) << " 右侧车位ID: "<<t_allocated_space_rigth.parkingspace_index_id();
  1295. error=query_the_optimal_parkspace_serverB3(t_allocated_space_temporary,car_info,terminal_id);
  1296. if ( error != Error_code::SUCCESS )
  1297. {
  1298. t_error.set_error_code(error.get_error_code());
  1299. t_error.set_error_level((message::Error_level)error.get_error_level());
  1300. t_error.set_error_description(error.get_error_description());
  1301. LOG(ERROR) << car_info.license()<<" 获取缓冲区车位失败 "<<error.to_string();
  1302. }
  1303. LOG(INFO) << " 缓冲区车位ID: "<<t_allocated_space_temporary.parkingspace_index_id();
  1304. if ( error != Error_code::SUCCESS )
  1305. {
  1306. t_error.set_error_code(error.get_error_code());
  1307. t_error.set_error_level((message::Error_level)error.get_error_level());
  1308. t_error.set_error_description(error.get_error_description());
  1309. LOG(ERROR) << car_info.license()<<" 获取空车位失败 "<<error.to_string();
  1310. }
  1311. else
  1312. {
  1313. }
  1314. //如果车辆不存在则获取一个空车位
  1315. // error=m_parkspace_operating_function.query_one_empty_parkspace(t_allocated_space);
  1316. if ( error != Error_code::SUCCESS )
  1317. {
  1318. t_error.set_error_code(error.get_error_code());
  1319. t_error.set_error_level((message::Error_level)error.get_error_level());
  1320. t_error.set_error_description(error.get_error_description());
  1321. LOG(ERROR) << car_info.license()<<" 获取空车位失败 "<<error.to_string();
  1322. }
  1323. else
  1324. {
  1325. //尚未加入操作回退步骤
  1326. //修改车位状态为锁定
  1327. t_allocated_space.set_parkingspace_status(message::Parkspace_status::eParkspace_locked);
  1328. t_allocated_space.mutable_car_info()->CopyFrom(car_info);
  1329. // 分配车位后更新数据库中车位状态
  1330. error=m_parkspace_operating_function.update_parkspace_data(t_allocated_space);
  1331. if ( error != SUCCESS )
  1332. {
  1333. t_error.set_error_code(error.get_error_code());
  1334. t_error.set_error_level((message::Error_level)error.get_error_level());
  1335. t_error.set_error_description(error.get_error_description());
  1336. LOG(ERROR) << car_info.license()<<" 更新车位数据失败 "<<error.to_string();
  1337. }
  1338. else
  1339. {
  1340. //修改车辆状态为停车中
  1341. message::Vehicle_status t_vehicle_status = message::Vehicle_status::eVehicle_parking;
  1342. error=m_parkspace_operating_function.update_vehicle_with_parkspace(t_allocated_space,t_vehicle_status);
  1343. if ( error != SUCCESS )
  1344. {
  1345. t_error.set_error_code(error.get_error_code());
  1346. t_error.set_error_level((message::Error_level)error.get_error_level());
  1347. t_error.set_error_description(error.get_error_description());
  1348. LOG(ERROR) << car_info.license()<<" 更新车辆数据失败 "<<error.to_string();
  1349. }
  1350. else
  1351. {
  1352. t_error.set_error_code(SUCCESS);
  1353. t_error.set_error_level(message::Error_level::NORMAL);
  1354. LOG(INFO) <<" 分配车位成功 "<<"车位ID:"<<t_allocated_space.parkingspace_index_id()<<" 车牌号:"<<t_allocated_space.car_info().license();
  1355. }
  1356. }
  1357. }
  1358. m_parkspace_lock.unlock();
  1359. }
  1360. response_msg.mutable_base_info()->CopyFrom(t_response_header);
  1361. response_msg.set_command_key(command_key);
  1362. response_msg.mutable_error_manager()->CopyFrom(t_error);
  1363. response_msg.mutable_allocated_space_info()->CopyFrom(t_allocated_space);
  1364. Communication_message response=Communication_message();
  1365. response.reset(t_response_header, response_msg.SerializeAsString());
  1366. Parkspace_communicator::get_instance_references().send_response(&response);
  1367. send_parkspace_data();
  1368. std::cout<<std::endl;
  1369. }
  1370. //查询车位线程函数
  1371. void Parkspace_manager::execute_for_search(message::Car_info car_info,std::string command_key)
  1372. {
  1373. LOG(INFO) << "查询车位 "<<"牌号:"<<car_info.license()<<" command_key="<<command_key;
  1374. //根据车辆凭证信息查询车辆位置
  1375. message::Parkspace_search_response_msg response_msg;
  1376. message::Base_info t_response_header;
  1377. message::Error_manager t_error;
  1378. message::Parkspace_info t_car_position;
  1379. t_response_header.set_msg_type(message::Message_type::eParkspace_search_response_msg);
  1380. t_response_header.set_timeout_ms(1000);
  1381. t_response_header.set_sender(message::Communicator::eParkspace);
  1382. t_response_header.set_receiver(message::Communicator::eMain);
  1383. //查询车辆位置
  1384. message::Parkspace_info parkspace_info;
  1385. Error_manager error=m_parkspace_operating_function.query_one_parkspace_with_license(car_info.license(),parkspace_info);
  1386. if ( error != SUCCESS )
  1387. {
  1388. t_error.set_error_code(error.get_error_code());
  1389. t_error.set_error_level((message::Error_level)error.get_error_level());
  1390. t_error.set_error_description(error.get_error_description());
  1391. LOG(ERROR) << "查询车位失败 "<<error.to_string();
  1392. }
  1393. else
  1394. {
  1395. t_error.set_error_code(SUCCESS);
  1396. t_error.set_error_level(message::Error_level::NORMAL);
  1397. LOG(INFO) << "车辆"<<parkspace_info.car_info().license()<<" 在"<<parkspace_info.parkingspace_index_id()<<"号车位上";
  1398. }
  1399. response_msg.mutable_base_info()->CopyFrom(t_response_header);
  1400. response_msg.set_command_key(command_key);
  1401. response_msg.mutable_error_manager()->CopyFrom(t_error);
  1402. response_msg.mutable_car_position()->CopyFrom(t_car_position);
  1403. Communication_message response=Communication_message();
  1404. response.reset(t_response_header, response_msg.SerializeAsString());
  1405. Parkspace_communicator::get_instance_references().send_response(&response);
  1406. std::cout<<std::endl;
  1407. }
  1408. //释放车位线程函数
  1409. void Parkspace_manager::execute_for_release(message::Parkspace_info space_info, std::string command_key)
  1410. {
  1411. LOG(INFO) << "释放车位 "<<"牌号:"<<space_info.car_info().license()<<" command_key="<<command_key;
  1412. //根据车位信息定位待释放车位位置,车辆凭证号用于校验
  1413. message::Parkspace_release_response_msg response_msg;
  1414. message::Base_info t_response_header;
  1415. t_response_header.set_msg_type(message::eParkspace_release_response_msg);
  1416. t_response_header.set_sender(message::eParkspace);
  1417. t_response_header.set_receiver(message::eMain);
  1418. t_response_header.set_timeout_ms(1000);
  1419. message::Error_manager t_error;
  1420. message::Parkspace_info t_release_space;
  1421. //找到待释放的车位
  1422. m_parkspace_lock.lock();
  1423. Error_manager error=m_parkspace_operating_function.query_one_parkspace_with_parkspace_id(space_info.parkingspace_index_id(),t_release_space);
  1424. if ( error != SUCCESS )
  1425. {
  1426. t_error.set_error_code(error.get_error_code());
  1427. t_error.set_error_level((message::Error_level)error.get_error_level());
  1428. t_error.set_error_description(error.get_error_description());
  1429. LOG(ERROR) << "释放车位失败 "<<error.to_string();
  1430. }
  1431. else if(!t_release_space.has_car_info())
  1432. {
  1433. t_error.set_error_code(PARKSPACE_ALLOCATOR_RELEASE_FAILED);
  1434. t_error.set_error_level(message::Error_level::MAJOR_ERROR);
  1435. LOG(WARNING) << "传入待释放车位无车辆信息";
  1436. }
  1437. else
  1438. {
  1439. t_release_space.set_parkingspace_status(message::Parkspace_status::eParkspace_empty);
  1440. error = m_parkspace_operating_function.update_parkspace_data(t_release_space);
  1441. if (error != SUCCESS)
  1442. {
  1443. t_error.set_error_code(error.get_error_code());
  1444. t_error.set_error_level((message::Error_level) error.get_error_level());
  1445. t_error.set_error_description(error.get_error_description());
  1446. LOG(ERROR) << "释放车位 更新数据库车位数据失败 " << error.to_string();
  1447. }
  1448. else
  1449. {
  1450. message::Vehicle_status t_vehicle_status = message::Vehicle_status::eVehicle_idle;
  1451. error = m_parkspace_operating_function.update_vehicle_with_parkspace(t_release_space, t_vehicle_status);
  1452. if (error != SUCCESS)
  1453. {
  1454. t_error.set_error_code(error.get_error_code());
  1455. t_error.set_error_level((message::Error_level) error.get_error_level());
  1456. t_error.set_error_description(error.get_error_description());
  1457. LOG(ERROR) << "释放车位 更新数据库车辆数据失败 " << error.to_string();
  1458. }
  1459. else
  1460. {
  1461. t_error.set_error_code(SUCCESS);
  1462. t_error.set_error_level(message::Error_level::NORMAL);
  1463. LOG(INFO) << "第:" << t_release_space.parkingspace_index_id() << "号位 车辆: " << t_release_space.car_info().license()
  1464. << " 释放成功";
  1465. //获取预约ID
  1466. int t_park_record_id;
  1467. error = m_parkspace_operating_function.query_vehicle(t_release_space.car_info().license(),
  1468. t_vehicle_status, t_park_record_id);
  1469. if (error != SUCCESS)
  1470. {
  1471. t_error.set_error_code(error.get_error_code());
  1472. t_error.set_error_level((message::Error_level) error.get_error_level());
  1473. t_error.set_error_description(error.get_error_description());
  1474. LOG(ERROR) << "释放车位 数据库查询车辆信息失败 " << error.to_string();
  1475. }
  1476. else if (t_vehicle_status == message::Vehicle_status::eVehicle_idle)
  1477. {
  1478. time_t tt = time(NULL);
  1479. tm *t = localtime(&tt);
  1480. char my_time_buf[255];
  1481. memset(my_time_buf, 0, 255);
  1482. sprintf(my_time_buf, "%d-%02d-%02d %02d:%02d:%02d",
  1483. t->tm_year + 1900,
  1484. t->tm_mon + 1,
  1485. t->tm_mday,
  1486. t->tm_hour,
  1487. t->tm_min,
  1488. t->tm_sec);
  1489. t_release_space.set_leave_time(my_time_buf);
  1490. error = m_parkspace_operating_function.update_parking_record(t_release_space, t_park_record_id);
  1491. if (error != SUCCESS)
  1492. {
  1493. t_error.set_error_code(error.get_error_code());
  1494. t_error.set_error_level((message::Error_level) error.get_error_level());
  1495. t_error.set_error_description(error.get_error_description());
  1496. LOG(ERROR) << "更新停车记录失败: " << error.to_string();
  1497. }
  1498. }
  1499. }
  1500. }
  1501. }
  1502. m_parkspace_lock.unlock();
  1503. response_msg.mutable_base_info()->CopyFrom(t_response_header);
  1504. response_msg.set_command_key(command_key);
  1505. response_msg.mutable_error_manager()->CopyFrom(t_error);
  1506. response_msg.mutable_release_space_info()->CopyFrom(t_release_space);
  1507. Communication_message response=Communication_message();
  1508. response.reset(t_response_header, response_msg.SerializeAsString());
  1509. Parkspace_communicator::get_instance_references().send_response(&response);
  1510. send_parkspace_data();
  1511. std::cout<<std::endl;
  1512. }
  1513. //强制更新车位信息线程函数
  1514. void Parkspace_manager::execute_for_force_update(message::Parkspace_info space_info, std::string command_key)
  1515. {
  1516. LOG(INFO) << "手动 "<<"牌号:"<<space_info.car_info().license()<<" command_key="<<command_key;
  1517. //根据车位信息定位待释放车位位置,车辆凭证号用于校验
  1518. //!!!!!此处跳过外部处理与调用的过程,直接在内部调用,发送分配结果用于测试,目前一直发布第一个车位
  1519. message::Parkspace_force_update_response_msg response_msg;
  1520. message::Base_info t_response_header;
  1521. t_response_header.set_msg_type(message::eParkspace_force_update_response_msg);
  1522. t_response_header.set_sender(message::eParkspace);
  1523. t_response_header.set_receiver(message::eMain);
  1524. t_response_header.set_timeout_ms(1000);
  1525. message::Error_manager t_error;
  1526. message::Parkspace_info t_update_space;
  1527. Error_manager error;
  1528. // id 9999为特殊情况,复位所有车位状态
  1529. if (space_info.parkingspace_index_id() == 9999)
  1530. {
  1531. // 复位所有车位状态
  1532. error=m_parkspace_operating_function.clear_all_parkspace_info();
  1533. if( error != SUCCESS)
  1534. {
  1535. t_error.set_error_code(error.get_error_code());
  1536. t_error.set_error_level((message::Error_level) error.get_error_level());
  1537. LOG(INFO) << "手动更新所有车位失败 "<<error.to_string();
  1538. }
  1539. else
  1540. {
  1541. t_error.set_error_code(SUCCESS);
  1542. t_error.set_error_level(message::Error_level::NORMAL);
  1543. LOG(INFO) << "所有车位已手动更新 ";
  1544. }
  1545. }
  1546. else
  1547. {
  1548. //手动修改车位信息
  1549. error = m_parkspace_operating_function.update_parkspace_data(t_update_space);
  1550. if (error != SUCCESS)
  1551. {
  1552. t_error.set_error_code(error.get_error_code());
  1553. t_error.set_error_level((message::Error_level)error.get_error_level());
  1554. LOG(INFO) << "手动 数据库更新车位失败 "<<error.to_string();
  1555. }
  1556. else
  1557. {
  1558. t_error.set_error_code(SUCCESS);
  1559. t_error.set_error_level(message::Error_level::NORMAL);
  1560. LOG(INFO) << "第" << t_update_space.parkingspace_index_id() << "号位已手动更新";
  1561. }
  1562. }
  1563. response_msg.mutable_base_info()->CopyFrom(t_response_header);
  1564. response_msg.set_command_key(command_key);
  1565. response_msg.mutable_error_manager()->CopyFrom(t_error);
  1566. response_msg.mutable_update_space_info()->CopyFrom(t_update_space);
  1567. Communication_message response=Communication_message();
  1568. response.reset(t_response_header, response_msg.SerializeAsString());
  1569. Parkspace_communicator::get_instance_references().send_response(&response);
  1570. send_parkspace_data();
  1571. }
  1572. //确认分配车位线程函数
  1573. void Parkspace_manager::execute_for_confirm_alloc(message::Parkspace_info space_info, std::string command_key)
  1574. {
  1575. LOG(INFO) << "确认分配 " << "牌号:" << space_info.car_info().license() << " command_key=" << command_key;
  1576. //根据车位信息定位待确认占用车位
  1577. message::Parkspace_confirm_alloc_response_msg response_msg;
  1578. message::Base_info t_response_header;
  1579. t_response_header.set_msg_type(message::eParkspace_confirm_alloc_response_msg);
  1580. t_response_header.set_sender(message::eParkspace);
  1581. t_response_header.set_receiver(message::eMain);
  1582. t_response_header.set_timeout_ms(1000);
  1583. message::Error_manager t_error;
  1584. message::Parkspace_info t_confirm_space;
  1585. Error_manager error;
  1586. //获取确认分配的车位
  1587. m_parkspace_lock.lock();
  1588. error = m_parkspace_operating_function.query_one_parkspace_with_parkspace_id(space_info.parkingspace_index_id(),
  1589. t_confirm_space);
  1590. if (error != SUCCESS)
  1591. {
  1592. t_error.set_error_code(error.get_error_code());
  1593. t_error.set_error_level((message::Error_level) error.get_error_level());
  1594. t_error.set_error_description(error.get_error_description());
  1595. LOG(ERROR) << "确认分配 查询车位信息失败 " << error.to_string();
  1596. }
  1597. else if (!t_confirm_space.has_car_info())
  1598. {
  1599. t_error.set_error_code(PARKSPACE_ALLOCATOR_RELEASE_FAILED);
  1600. t_error.set_error_level(message::Error_level::MAJOR_ERROR);
  1601. LOG(WARNING) << "传入待确认车位无车辆信息";
  1602. }
  1603. else
  1604. {
  1605. //校验车位状态是否为被锁定
  1606. if (t_confirm_space.parkingspace_status() != message::Parkspace_status::eParkspace_locked)
  1607. {
  1608. t_error.set_error_code(DB_QUERY_DATA_FAILED);
  1609. t_error.set_error_level(message::Error_level::MINOR_ERROR);
  1610. t_error.set_error_description("查询车位状态错误");
  1611. LOG(ERROR) << "确认分配 查询车位状态错误 " << error.to_string();
  1612. }
  1613. else
  1614. {
  1615. //修改车位状态为占用
  1616. t_confirm_space.set_parkingspace_status(message::Parkspace_status::eParkspace_occupied);
  1617. error = m_parkspace_operating_function.update_parkspace_data(t_confirm_space);
  1618. if (error != SUCCESS)
  1619. {
  1620. t_error.set_error_code(error.get_error_code());
  1621. t_error.set_error_level((message::Error_level) error.get_error_level());
  1622. LOG(INFO) << "确认分配 数据库更新车位失败 " << error.to_string();
  1623. }
  1624. else
  1625. {
  1626. //修改车辆状态为已入库
  1627. message::Vehicle_status t_vehicle_status = message::Vehicle_status::eVehicle_in_garage;
  1628. error = m_parkspace_operating_function.update_vehicle_with_parkspace(t_confirm_space, t_vehicle_status);
  1629. if (error != SUCCESS)
  1630. {
  1631. t_error.set_error_code(error.get_error_code());
  1632. t_error.set_error_level((message::Error_level) error.get_error_level());
  1633. t_error.set_error_description(error.get_error_description());
  1634. LOG(ERROR) << "确认分配 更新数据库车辆数据失败 " << error.to_string();
  1635. }
  1636. t_error.set_error_code(SUCCESS);
  1637. t_error.set_error_level(message::Error_level::NORMAL);
  1638. LOG(INFO) << "第:" << t_confirm_space.parkingspace_index_id() << "号位 车辆: " << t_confirm_space.car_info().license()<< " 确认占用成功";
  1639. //插入停车记录
  1640. time_t tt = time(NULL);
  1641. tm *t = localtime(&tt);
  1642. char my_time_buf[255];
  1643. memset(my_time_buf, 0, 255);
  1644. sprintf(my_time_buf, "%d-%02d-%02d %02d:%02d:%02d",
  1645. t->tm_year + 1900,
  1646. t->tm_mon + 1,
  1647. t->tm_mday,
  1648. t->tm_hour,
  1649. t->tm_min,
  1650. t->tm_sec);
  1651. t_confirm_space.set_entry_time(my_time_buf);
  1652. error = m_parkspace_operating_function.insert_parking_record(t_confirm_space);
  1653. if ( error != SUCCESS )
  1654. {
  1655. t_error.set_error_code(error.get_error_code());
  1656. t_error.set_error_level((message::Error_level) error.get_error_level());
  1657. LOG(ERROR) << "插入停车记录失败: " << error.to_string();
  1658. }
  1659. //查询停车记录的ID
  1660. int t_record_id;
  1661. error = m_parkspace_operating_function.query_parking_record(t_confirm_space,t_record_id);
  1662. if ( error != SUCCESS )
  1663. {
  1664. t_error.set_error_code(error.get_error_code());
  1665. t_error.set_error_level((message::Error_level) error.get_error_level());
  1666. LOG(ERROR) << "查询停车记录ID失败: " << error.to_string();
  1667. }
  1668. //更新停车记录ID
  1669. error = m_parkspace_operating_function.update_record_id(t_confirm_space.car_info().license(),t_record_id);
  1670. if ( error != SUCCESS )
  1671. {
  1672. t_error.set_error_code(error.get_error_code());
  1673. t_error.set_error_level((message::Error_level) error.get_error_level());
  1674. LOG(ERROR) << "更新停车记录ID失败: " << error.to_string();
  1675. }
  1676. }
  1677. }
  1678. }
  1679. m_parkspace_lock.unlock();
  1680. response_msg.mutable_base_info()->CopyFrom(t_response_header);
  1681. response_msg.set_command_key(command_key);
  1682. response_msg.mutable_error_manager()->CopyFrom(t_error);
  1683. response_msg.mutable_confirm_alloc_space_info()->CopyFrom(t_confirm_space);
  1684. Communication_message response=Communication_message();
  1685. response.reset(t_response_header, response_msg.SerializeAsString());
  1686. Parkspace_communicator::get_instance_references().send_response(&response);
  1687. send_parkspace_data();
  1688. std::cout<<std::endl;
  1689. }