ObjectData.cpp 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. //
  2. // Created by wrede on 19.04.16.
  3. //
  4. #include <cmath>
  5. #include "ObjectData.h"
  6. #include "../util/MyMath.h"
  7. namespace core
  8. {
  9. const std::string ObjectData::CONSTRAINT_FRAME_DIFFERENCE = "frame_difference";
  10. const std::string ObjectData::CONSTRAINT_SCORE_DIFFERENCE = "score_difference";
  11. ObjectData::ObjectData()
  12. : frame_index_(0), is_virtual_(true), detection_score_(0.0)
  13. {
  14. /* EMPTY */
  15. }
  16. ObjectData::ObjectData(std::size_t frame_index)
  17. : frame_index_(frame_index), is_virtual_(false), detection_score_(0.0)
  18. {
  19. /* EMPTY */
  20. }
  21. std::size_t ObjectData::GetFrameIndex() const
  22. {
  23. return frame_index_;
  24. }
  25. bool ObjectData::IsVirtual() const
  26. {
  27. return is_virtual_;
  28. }
  29. void ObjectData::Print(std::ostream &os) const
  30. {
  31. if (is_virtual_)
  32. {
  33. os << "Object{-}";
  34. }
  35. else
  36. {
  37. os << "Object{" << frame_index_ << "}";
  38. }
  39. }
  40. double ObjectData::CompareTo(ObjectDataPtr obj) const
  41. {
  42. /* EMPTY */
  43. return 0.0;
  44. }
  45. bool ObjectData::IsWithinConstraints(ObjectDataPtr obj,
  46. std::unordered_map<std::string, double> & constraints)
  47. const
  48. {
  49. if (constraints.count(CONSTRAINT_FRAME_DIFFERENCE) > 0)
  50. {
  51. size_t frame_difference;
  52. // check the size to prevent negative values for unsigned type
  53. if (frame_index_ > obj->GetFrameIndex()) {
  54. frame_difference = frame_index_ - obj->GetFrameIndex();
  55. } else {
  56. frame_difference = obj->GetFrameIndex() - frame_index_;
  57. }
  58. if (frame_difference > constraints[CONSTRAINT_FRAME_DIFFERENCE]) {
  59. return false;
  60. }
  61. }
  62. if (constraints.count(CONSTRAINT_SCORE_DIFFERENCE) > 0) {
  63. double score_difference = fabs(detection_score_ - obj->GetDetectionScore());
  64. if (score_difference > constraints[CONSTRAINT_SCORE_DIFFERENCE]) {
  65. return false;
  66. }
  67. }
  68. return true;
  69. }
  70. ObjectDataPtr ObjectData::Interpolate(ObjectDataPtr obj, double fraction) const
  71. {
  72. size_t index = static_cast<size_t>(
  73. util::MyMath::Lerp(GetFrameIndex(), obj->GetFrameIndex(), fraction));
  74. return ObjectDataPtr(new ObjectData(index));
  75. }
  76. std::ostream& operator<<(std::ostream &os, const ObjectData &obj)
  77. {
  78. obj.Print(os);
  79. return os;
  80. }
  81. void ObjectData::SetFrameIndex(size_t index)
  82. {
  83. frame_index_ = index;
  84. }
  85. void ObjectData::Visualize(cv::Mat& image, cv::Scalar& color, double alpha) const
  86. {
  87. /* EMPTY */
  88. }
  89. void ObjectData::SetDetectionScore(double score)
  90. {
  91. detection_score_ = score;
  92. }
  93. double ObjectData::GetDetectionScore() const
  94. {
  95. return detection_score_;
  96. }
  97. std::string ObjectData::ToString(char delimiter) const
  98. {
  99. return std::to_string(frame_index_);
  100. }
  101. }