diff --git a/include/overworld/Perception/Managers/ObjectsPerceptionManager.h b/include/overworld/Perception/Managers/ObjectsPerceptionManager.h index 9fa8530d..eca17d0c 100644 --- a/include/overworld/Perception/Managers/ObjectsPerceptionManager.h +++ b/include/overworld/Perception/Managers/ObjectsPerceptionManager.h @@ -45,7 +45,7 @@ class ObjectsPerceptionManager : public EntitiesPerceptionManager void stopSimulation(Object* object, bool erase = true); std::vector getPoisInFov(Object* object); - bool isObjectsInFovAabb(std::vector objects); + std::vector isObjectsInFovAabb(std::vector objects); bool shouldBeSeen(Object* object, const std::vector& pois); std::unordered_set getObjectsInCamera(); diff --git a/src/Perception/Managers/ObjectsPerceptionManager.cpp b/src/Perception/Managers/ObjectsPerceptionManager.cpp index 66d767ae..c93de739 100644 --- a/src/Perception/Managers/ObjectsPerceptionManager.cpp +++ b/src/Perception/Managers/ObjectsPerceptionManager.cpp @@ -220,11 +220,12 @@ void ObjectsPerceptionManager::reasoningOnUpdate() if(no_data_objects.size()) { - if(isObjectsInFovAabb(no_data_objects)) + auto objects_in_fov = isObjectsInFovAabb(no_data_objects); + if(objects_in_fov.size()) { auto objects_in_camera = getObjectsInCamera(); - for(auto no_data_obj : no_data_objects) + for(auto no_data_obj : objects_in_fov) { // equivalent to shouldBeSeen if(objects_in_camera.find(no_data_obj->bulletId()) != objects_in_camera.end()) @@ -373,10 +374,12 @@ std::vector ObjectsPerceptionManager::getPoisInFov(Object* obje return pois_in_fov; } -bool ObjectsPerceptionManager::isObjectsInFovAabb(std::vector objects) +std::vector ObjectsPerceptionManager::isObjectsInFovAabb(std::vector objects) { + std::vector res; for(auto object : objects) { + size_t nb_in_fov = 0; std::array points = { Pose({object->getAabb().min[0], object->getAabb().min[1], object->getAabb().min[2]}, {0,0,0,1}), Pose({object->getAabb().min[0], object->getAabb().min[1], object->getAabb().max[2]}, {0,0,0,1}), Pose({object->getAabb().min[0], object->getAabb().max[1], object->getAabb().min[2]}, {0,0,0,1}), @@ -389,12 +392,16 @@ bool ObjectsPerceptionManager::isObjectsInFovAabb(std::vector objects) for(const auto& point : points) { auto point_in_head = point.transformIn(myself_agent_->getHead()->pose()); - if (myself_agent_->getFieldOfView().hasIn(point_in_head)) - return true; + if (myself_agent_->getFieldOfView().hasIn(point_in_head, 2)) + { + nb_in_fov ++; + if(nb_in_fov >= 2) + res.push_back(object); + } } } - return false; + return res; } bool ObjectsPerceptionManager::shouldBeSeen(Object* object, const std::vector& pois)