common_data.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382
  1. //
  2. // Created by huli on 2020/9/8.
  3. //
  4. #include "common_data.h"
  5. void Common_data::copy_data(Car_measure_information& car_measure_information_out, const message::Locate_information& locate_information_in)
  6. {
  7. if ( locate_information_in.has_locate_x() )
  8. {
  9. car_measure_information_out.center_x = locate_information_in.locate_x();
  10. }
  11. else
  12. {
  13. car_measure_information_out.center_x = 0;
  14. }
  15. if ( locate_information_in.has_locate_y() )
  16. {
  17. car_measure_information_out.center_y = locate_information_in.locate_y();
  18. }
  19. else
  20. {
  21. car_measure_information_out.center_y = 0;
  22. }
  23. if ( locate_information_in.has_locate_angle() )
  24. {
  25. car_measure_information_out.car_angle = locate_information_in.locate_angle();
  26. }
  27. else
  28. {
  29. car_measure_information_out.car_angle = 0;
  30. }
  31. if ( locate_information_in.has_locate_length() )
  32. {
  33. car_measure_information_out.car_length = locate_information_in.locate_length();
  34. }
  35. else
  36. {
  37. car_measure_information_out.car_length = 0;
  38. }
  39. if ( locate_information_in.has_locate_width() )
  40. {
  41. car_measure_information_out.car_width = locate_information_in.locate_width();
  42. }
  43. else
  44. {
  45. car_measure_information_out.car_width = 0;
  46. }
  47. if ( locate_information_in.has_locate_height() )
  48. {
  49. car_measure_information_out.car_height = locate_information_in.locate_height();
  50. }
  51. else
  52. {
  53. car_measure_information_out.car_height = 0;
  54. }
  55. if ( locate_information_in.has_locate_wheel_base() )
  56. {
  57. car_measure_information_out.car_wheel_base = locate_information_in.locate_wheel_base();
  58. }
  59. else
  60. {
  61. car_measure_information_out.car_wheel_base = 0;
  62. }
  63. if ( locate_information_in.has_locate_wheel_width() )
  64. {
  65. car_measure_information_out.car_wheel_width = locate_information_in.locate_wheel_width();
  66. }
  67. else
  68. {
  69. car_measure_information_out.car_wheel_width = 0;
  70. }
  71. if ( locate_information_in.has_locate_front_theta() )
  72. {
  73. car_measure_information_out.car_front_theta = locate_information_in.locate_front_theta();
  74. }
  75. else
  76. {
  77. car_measure_information_out.car_front_theta = 0;
  78. }
  79. if ( locate_information_in.has_locate_correct() )
  80. {
  81. car_measure_information_out.correctness = locate_information_in.locate_correct();
  82. }
  83. else
  84. {
  85. car_measure_information_out.correctness = false;
  86. }
  87. }
  88. void Common_data::copy_data(message::Locate_information& locate_information_out, const Car_measure_information& car_measure_information_in)
  89. {
  90. locate_information_out.set_locate_x(car_measure_information_in.center_x);
  91. locate_information_out.set_locate_y(car_measure_information_in.center_y);
  92. locate_information_out.set_locate_angle(car_measure_information_in.car_angle);
  93. locate_information_out.set_locate_length(car_measure_information_in.car_length);
  94. locate_information_out.set_locate_width(car_measure_information_in.car_width);
  95. locate_information_out.set_locate_height(car_measure_information_in.car_height);
  96. locate_information_out.set_locate_wheel_base(car_measure_information_in.car_wheel_base);
  97. locate_information_out.set_locate_wheel_width(car_measure_information_in.car_wheel_width);
  98. locate_information_out.set_locate_front_theta(car_measure_information_in.car_front_theta);
  99. locate_information_out.set_locate_correct(car_measure_information_in.correctness);
  100. }
  101. void Common_data::copy_data(Car_information& car_information_out, const message::Car_info& car_info_in)
  102. {
  103. if ( car_info_in.has_license() )
  104. {
  105. car_information_out.license = car_info_in.license();
  106. }
  107. else
  108. {
  109. car_information_out.license.clear();
  110. }
  111. if ( car_info_in.has_car_length() )
  112. {
  113. car_information_out.car_length = car_info_in.car_length();
  114. }
  115. else
  116. {
  117. car_information_out.car_length = 0;
  118. }
  119. if ( car_info_in.has_car_width() )
  120. {
  121. car_information_out.car_width = car_info_in.car_width();
  122. }
  123. else
  124. {
  125. car_information_out.car_width = 0;
  126. }
  127. if ( car_info_in.has_car_height() )
  128. {
  129. car_information_out.car_height = car_info_in.car_height();
  130. }
  131. else
  132. {
  133. car_information_out.car_height = 0;
  134. }
  135. if ( car_info_in.has_car_wheel_base() )
  136. {
  137. car_information_out.car_wheel_base = car_info_in.car_wheel_base();
  138. }
  139. else
  140. {
  141. car_information_out.car_wheel_base = 0;
  142. }
  143. if ( car_info_in.has_car_wheel_width() )
  144. {
  145. car_information_out.car_wheel_width = car_info_in.car_wheel_width();
  146. }
  147. else
  148. {
  149. car_information_out.car_wheel_width = 0;
  150. }
  151. }
  152. void Common_data::copy_data(message::Car_info& car_info_out, const Car_information& car_information_in)
  153. {
  154. car_info_out.set_license(car_information_in.license);
  155. car_info_out.set_car_length(car_information_in.car_length);
  156. car_info_out.set_car_width(car_information_in.car_width);
  157. car_info_out.set_car_height(car_information_in.car_height);
  158. car_info_out.set_car_wheel_base(car_information_in.car_wheel_base);
  159. car_info_out.set_car_wheel_width(car_information_in.car_wheel_width);
  160. }
  161. void Common_data::copy_data(Parkspace_information& parkspace_information_out, const message::Parkspace_info& parkspace_info_in)
  162. {
  163. if ( parkspace_info_in.has_parkspace_id() )
  164. {
  165. parkspace_information_out.parkspace_id = parkspace_info_in.parkspace_id();
  166. }
  167. else
  168. {
  169. parkspace_information_out.parkspace_id = 0;
  170. }
  171. if ( parkspace_info_in.has_block_id() )
  172. {
  173. parkspace_information_out.block_id = parkspace_info_in.block_id();
  174. }
  175. else
  176. {
  177. parkspace_information_out.block_id = 0;
  178. }
  179. if ( parkspace_info_in.has_floor() )
  180. {
  181. parkspace_information_out.floor_id = parkspace_info_in.floor();
  182. }
  183. else
  184. {
  185. parkspace_information_out.floor_id = 0;
  186. }
  187. if ( parkspace_info_in.has_index() )
  188. {
  189. parkspace_information_out.room_id = parkspace_info_in.index();
  190. }
  191. else
  192. {
  193. parkspace_information_out.room_id = 0;
  194. }
  195. if ( parkspace_info_in.has_direction() )
  196. {
  197. parkspace_information_out.direction = (Common_data::Direction)parkspace_info_in.direction();
  198. }
  199. else
  200. {
  201. parkspace_information_out.direction = DIRECTION_UNKNOW;
  202. }
  203. if ( parkspace_info_in.has_length() )
  204. {
  205. parkspace_information_out.parkspace_length = parkspace_info_in.length();
  206. }
  207. else
  208. {
  209. parkspace_information_out.parkspace_length = 0;
  210. }
  211. if ( parkspace_info_in.has_width() )
  212. {
  213. parkspace_information_out.parkspace_width = parkspace_info_in.width();
  214. }
  215. else
  216. {
  217. parkspace_information_out.parkspace_width = 0;
  218. }
  219. if ( parkspace_info_in.has_height() )
  220. {
  221. parkspace_information_out.parkspace_height = parkspace_info_in.height();
  222. }
  223. else
  224. {
  225. parkspace_information_out.parkspace_height = 0;
  226. }
  227. if ( parkspace_info_in.has_parkspace_status() )
  228. {
  229. parkspace_information_out.parkspace_status = (Common_data::Parkspace_status)parkspace_info_in.parkspace_status();
  230. }
  231. else
  232. {
  233. parkspace_information_out.parkspace_status = PARKSPACE_EMPTY;
  234. }
  235. if ( parkspace_info_in.has_car_info() )
  236. {
  237. copy_data(parkspace_information_out.car_information, (message::Car_info&) parkspace_info_in.car_info());
  238. }
  239. else
  240. {
  241. Car_information temp;
  242. parkspace_information_out.car_information = temp;
  243. }
  244. if ( parkspace_info_in.has_entry_time() )
  245. {
  246. parkspace_information_out.car_entry_time = parkspace_info_in.entry_time();
  247. }
  248. else
  249. {
  250. parkspace_information_out.car_entry_time.clear();
  251. }
  252. if ( parkspace_info_in.has_leave_time() )
  253. {
  254. parkspace_information_out.car_leave_time = parkspace_info_in.leave_time();
  255. }
  256. else
  257. {
  258. parkspace_information_out.car_leave_time.clear();
  259. }
  260. if ( parkspace_info_in.has_parkspace_path() )
  261. {
  262. parkspace_information_out.parkspace_path = (Common_data::Parkspace_path)parkspace_info_in.parkspace_path();
  263. }
  264. else
  265. {
  266. parkspace_information_out.parkspace_path = UNKNOW_PATH;
  267. }
  268. if ( parkspace_info_in.has_path_estimate_time() )
  269. {
  270. parkspace_information_out.path_estimate_time = parkspace_info_in.path_estimate_time();
  271. }
  272. else
  273. {
  274. parkspace_information_out.car_leave_time.clear();
  275. }
  276. if ( parkspace_info_in.has_parkspace_status_target() )
  277. {
  278. parkspace_information_out.parkspace_status_target = (Common_data::Parkspace_status)parkspace_info_in.parkspace_status_target();
  279. }
  280. else
  281. {
  282. parkspace_information_out.parkspace_status_target = PARKSPACE_EMPTY;
  283. }
  284. }
  285. void Common_data::copy_data(message::Parkspace_info& parkspace_info_out, const Parkspace_information& parkspace_information_in)
  286. {
  287. parkspace_info_out.set_parkspace_id(parkspace_information_in.parkspace_id);
  288. parkspace_info_out.set_block_id(parkspace_information_in.block_id);
  289. parkspace_info_out.set_floor(parkspace_information_in.floor_id);
  290. parkspace_info_out.set_index(parkspace_information_in.room_id);
  291. parkspace_info_out.set_direction((message::Direction)parkspace_information_in.direction);
  292. parkspace_info_out.set_length(parkspace_information_in.parkspace_length);
  293. parkspace_info_out.set_width(parkspace_information_in.parkspace_width);
  294. parkspace_info_out.set_height(parkspace_information_in.parkspace_height);
  295. parkspace_info_out.set_parkspace_status((message::Parkspace_status)parkspace_information_in.parkspace_status);
  296. copy_data(*parkspace_info_out.mutable_car_info(), parkspace_information_in.car_information);
  297. parkspace_info_out.set_entry_time(parkspace_information_in.car_entry_time);
  298. parkspace_info_out.set_leave_time(parkspace_information_in.car_leave_time);
  299. parkspace_info_out.set_parkspace_path((message::Parkspace_path)parkspace_information_in.parkspace_path);
  300. parkspace_info_out.set_path_estimate_time(parkspace_information_in.path_estimate_time);
  301. parkspace_info_out.set_parkspace_status_target((message::Parkspace_status)parkspace_information_in.parkspace_status_target);
  302. }
  303. void Common_data::transform_data(Car_information& car_information_out, const Car_measure_information& car_measure_information_in)
  304. {
  305. car_information_out.license.clear();
  306. car_information_out.car_length = car_measure_information_in.car_length;
  307. car_information_out.car_width = car_measure_information_in.car_width;
  308. car_information_out.car_height = car_measure_information_in.car_height;
  309. car_information_out.car_wheel_base = car_measure_information_in.car_wheel_base;
  310. car_information_out.car_wheel_width = car_measure_information_in.car_wheel_width;
  311. }
  312. void Common_data::transform_data(Car_measure_information& car_measure_information_out, const Car_information& car_informatio_in)
  313. {
  314. car_measure_information_out.center_x = 0;
  315. car_measure_information_out.center_y = 0;
  316. car_measure_information_out.car_angle = 0;
  317. car_measure_information_out.car_length = car_informatio_in.car_length;
  318. car_measure_information_out.car_width = car_informatio_in.car_width;
  319. car_measure_information_out.car_height = car_informatio_in.car_height;
  320. car_measure_information_out.car_wheel_base = car_informatio_in.car_wheel_base;
  321. car_measure_information_out.car_wheel_width = car_informatio_in.car_wheel_width;
  322. car_measure_information_out.car_front_theta = 0;
  323. car_measure_information_out.correctness = false;
  324. }
  325. void Common_data::transform_data(Car_wheel_information& car_wheel_information_out, const Car_measure_information& car_measure_information_in)
  326. {
  327. car_wheel_information_out.center_x = car_measure_information_in.center_x;
  328. car_wheel_information_out.center_y = car_measure_information_in.center_y;
  329. car_wheel_information_out.car_angle = car_measure_information_in.car_angle;
  330. car_wheel_information_out.car_wheel_base = car_measure_information_in.car_wheel_base;
  331. car_wheel_information_out.car_wheel_width = car_measure_information_in.car_wheel_width;
  332. car_wheel_information_out.car_front_theta = car_measure_information_in.car_front_theta;
  333. car_wheel_information_out.correctness = car_measure_information_in.correctness;
  334. }
  335. void Common_data::transform_data(Car_measure_information& car_measure_information_out, const Car_wheel_information& car_wheel_information_in)
  336. {
  337. car_measure_information_out.center_x = car_wheel_information_in.center_x;
  338. car_measure_information_out.center_y = car_wheel_information_in.center_y;
  339. car_measure_information_out.car_angle = car_wheel_information_in.car_angle;
  340. car_measure_information_out.car_length = 0;
  341. car_measure_information_out.car_width = 0;
  342. car_measure_information_out.car_height = 0;
  343. car_measure_information_out.car_wheel_base = car_wheel_information_in.car_wheel_base;
  344. car_measure_information_out.car_wheel_width = car_wheel_information_in.car_wheel_width;
  345. car_measure_information_out.car_front_theta = car_wheel_information_in.car_front_theta;
  346. car_measure_information_out.correctness = car_wheel_information_in.correctness;
  347. }
  348. bool Common_data::approximate(float a, float b, float rate)
  349. {
  350. if ( a >= b*(1-rate) && a< b*(1+rate))
  351. {
  352. return true;
  353. }
  354. else
  355. {
  356. return false;
  357. }
  358. }