From 1f6389dbedb0f0037b902c01c85e68cb077c54d7 Mon Sep 17 00:00:00 2001 From: LAGNEAU Romain Date: Wed, 6 Nov 2024 10:38:19 +0100 Subject: [PATCH 1/2] [FIX] Fixed the memorization of the voting points for the CHT The voting points vector was not reinitialized when evaluating a new center, it remembered the voting points for the same radii but other circles --- modules/imgproc/src/vpCircleHoughTransform_circles.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/imgproc/src/vpCircleHoughTransform_circles.cpp b/modules/imgproc/src/vpCircleHoughTransform_circles.cpp index ee328335c6..dfda9b692b 100644 --- a/modules/imgproc/src/vpCircleHoughTransform_circles.cpp +++ b/modules/imgproc/src/vpCircleHoughTransform_circles.cpp @@ -139,7 +139,6 @@ vpCircleHoughTransform::computeCircleCandidates() nbBins = std::max(static_cast(1), nbBins); // Avoid having 0 bins, which causes segfault std::vector radiusAccumList; // Radius accumulator for each center candidates. std::vector radiusActualValueList; // Vector that contains the actual distance between the edge points and the center candidates. - std::vector > > votingPoints(nbBins); // Vectors that contain the points voting for each radius bin float rmin2 = m_algoParams.m_minRadius * m_algoParams.m_minRadius; float rmax2 = m_algoParams.m_maxRadius * m_algoParams.m_maxRadius; @@ -153,6 +152,7 @@ vpCircleHoughTransform::computeCircleCandidates() data.m_recordVotingPoints = m_algoParams.m_recordVotingPoints; for (size_t i = 0; i < nbCenterCandidates; ++i) { + std::vector > > votingPoints(nbBins); // Vectors that contain the points voting for each radius bin std::pair centerCandidate = m_centerCandidatesList[i]; // Initialize the radius accumulator of the candidate with 0s radiusAccumList.clear(); From 53b3080dfb71efce0731caabca58afb10d4507bb Mon Sep 17 00:00:00 2001 From: LAGNEAU Romain Date: Wed, 6 Nov 2024 11:16:56 +0100 Subject: [PATCH 2/2] [CORE] Added some method to ease the use of voting points --- .../visp3/imgproc/vpCircleHoughTransform.h | 48 +++++++++++++++++++ .../src/vpCircleHoughTransform_common.cpp | 3 ++ 2 files changed, 51 insertions(+) diff --git a/modules/imgproc/include/visp3/imgproc/vpCircleHoughTransform.h b/modules/imgproc/include/visp3/imgproc/vpCircleHoughTransform.h index 7448ea4722..c39f1aa2ba 100644 --- a/modules/imgproc/include/visp3/imgproc/vpCircleHoughTransform.h +++ b/modules/imgproc/include/visp3/imgproc/vpCircleHoughTransform.h @@ -1042,10 +1042,39 @@ class VISP_EXPORT vpCircleHoughTransform } } + /*! + * \brief Set the mask that permits to ignore some pixels when performing the circle detection. + * + * \param[in] mask A boolean image where pixels set to true means that the pixel + * must be considered and set to false means that the pixel must be ignored. + */ inline void setMask(const vpImage &mask) { mp_mask = &mask; } + + /*! + * \brief Set the mask that permits to ignore some pixels when performing the circle detection. + * + * \param[in] mask Either a boolean image where pixels set to true means that the pixel + * must be considered and set to false means that the pixel must be ignored, or nullptr + * to deactivate the mask. + */ + inline void setMask(const vpImage *mask) + { + mp_mask = mask; + } + + /*! + * \brief Permits to either activate or deactivate the memorization + * of the points that voted for the detected circles. + * + * \param[in] record True to activate the feature, false to deactivate it. + */ + inline void setRecordVotingPoints(const bool &record) + { + m_algoParams.m_recordVotingPoints = record; + } //@} /** @name Getters */ @@ -1179,6 +1208,25 @@ class VISP_EXPORT vpCircleHoughTransform { return m_finalCircleVotes; } + + /*! + * Get the points that voted for the detections that are outputed by vpCircleHoughTransform::detect(). + */ + inline std::vector > > getDetectionsVotingPoints() const + { + if (!m_algoParams.m_recordVotingPoints) { + throw(vpException(vpException::fatalError, "Asking voting points when it was not asked to remember them.")); + } + return m_finalCirclesVotingPoints; + } + + /*! + * Returns true if it was asked to record the points that voted for the detections. + */ + inline bool getRecordVotingPoints() const + { + return m_algoParams.getRecordVotingPoints(); + } //@} /*! diff --git a/modules/imgproc/src/vpCircleHoughTransform_common.cpp b/modules/imgproc/src/vpCircleHoughTransform_common.cpp index 20135a0574..e65d0e7982 100644 --- a/modules/imgproc/src/vpCircleHoughTransform_common.cpp +++ b/modules/imgproc/src/vpCircleHoughTransform_common.cpp @@ -268,8 +268,11 @@ vpCircleHoughTransform::detect(const vpImage &I) m_circleCandidates.clear(); m_circleCandidatesVotes.clear(); m_circleCandidatesProbabilities.clear(); + m_circleCandidatesVotingPoints.clear(); m_finalCircles.clear(); m_finalCircleVotes.clear(); + m_finalCirclesProbabilities.clear(); + m_finalCirclesVotingPoints.clear(); // Ensuring that the difference between the max and min radii is big enough to take into account // the pixelization of the image