detect_manager.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. #pragma once
  2. #include <thread>
  3. #include <Eigen/Core>
  4. #include <Eigen/Geometry>
  5. #include "tool/error_code.hpp"
  6. #include "ceres_detect/detect_wheel_ceres.h"
  7. #include "proto/enum_type.pb.h"
  8. #include "proto/detect_message.pb.h"
  9. #include "thread/thread_condition.h"
  10. #include "vzense/device_tof3d.h"
  11. #include "detect/ceres_detect/car_pose_detector.h"
  12. #include "detect/ceres_detect/wheel_detector.h"
  13. #include "detect/ceres_detect/detect_wheel_ceres.h"
  14. #include "detect/data_buf_lable.hpp"
  15. #include "communication/transitData.h"
  16. #include "proto/def.grpc.pb.h"
  17. class DetectManager {
  18. public:
  19. struct DetectResult {
  20. WheelCeresDetector::WheelDetectResult wheel[DeviceAzimuth::DEVICE_AZIMUTH_MAX];
  21. Car_pose_detector::CarDetectResult car;
  22. void reset() {
  23. for (int i = 0; i < DeviceAzimuth::DEVICE_AZIMUTH_MAX; i++) {
  24. wheel[i].reset();
  25. }
  26. car.reset();
  27. }
  28. std::string info() {
  29. std::string str = car.info();
  30. for (int i = 0; i < DeviceAzimuth::DEVICE_AZIMUTH_MAX; i++) {
  31. str += wheel[i].info();
  32. }
  33. return str;
  34. }
  35. };
  36. struct RecordImages {
  37. std::string name_1; // 图片名, 表示图片被保存时的时间;
  38. std::string name_2;
  39. std::string name_3;
  40. std::string name_4;
  41. cv::Mat img_1; // 四和一图片, 第一张是第一次识别到一个识别结果情况下的图片
  42. cv::Mat img_2; // 四和一图片, 第二张是第一次识别到二个识别结果情况下的图片
  43. cv::Mat img_3; // 四和一图片, 第三张是第一次识别到三个识别结果情况下的图片
  44. cv::Mat img_4; // 四和一图片, 第四张是第一次识别到四个识别结果情况下的图片
  45. };
  46. public:
  47. static DetectManager *iter() {
  48. static DetectManager *instance = nullptr;
  49. if (instance == nullptr) {
  50. instance = new DetectManager();
  51. }
  52. return instance;
  53. }
  54. ~DetectManager() = default;
  55. Error_manager Init(const google::protobuf::RepeatedPtrField<tof3dVzenseEtc> &tof_devices);
  56. Error_manager Release();
  57. Error_manager Stop();
  58. Error_manager Continue();
  59. MeasureStatu getMeasureResult(DetectResult &result);
  60. Error_manager carMoveStatus();
  61. protected:
  62. Error_manager updateTrans(const DeviceAzimuth &azimuth, const CoordinateTransformation3D &trans);
  63. void run();
  64. void stop();
  65. // 车轮点云优化
  66. Error_manager WheelCloudOptimize(std::vector<pcl::PointCloud<pcl::PointXYZ>::Ptr> &vct_wheel_cloud, DetectResult &result);
  67. private:
  68. std::thread *m_thread;
  69. Thread_condition m_condit;
  70. TimedLockData<bool> move_statu;
  71. TimedLockData<MeasureStatu> detect_statu;
  72. TimedLockData<Eigen::Matrix4f> rotation_matrix4[DeviceAzimuth::DEVICE_AZIMUTH_MAX];
  73. TimedLockData<DetectResult> m_detect_result_time_lock_data;
  74. };