scansegment.hpp 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. // This file is part of OpenCV project.
  2. // It is subject to the license terms in the LICENSE file found in the top-level directory
  3. // of this distribution and at http://opencv.org/license.html.
  4. //
  5. // Copyright (C) 2021, Dr Seng Cheong Loke (lokesengcheong@gmail.com)
  6. #ifndef __OPENCV_XIMGPROC_SCANSEGMENT_HPP__
  7. #define __OPENCV_XIMGPROC_SCANSEGMENT_HPP__
  8. #include <opencv2/core.hpp>
  9. namespace cv { namespace ximgproc {
  10. /** @brief Class implementing the F-DBSCAN (Accelerated superpixel image segmentation with a parallelized DBSCAN algorithm) superpixels
  11. algorithm by Loke SC, et al. @cite loke2021accelerated for original paper.
  12. The algorithm uses a parallelised DBSCAN cluster search that is resistant to noise, competitive in segmentation quality, and faster than
  13. existing superpixel segmentation methods. When tested on the Berkeley Segmentation Dataset, the average processing speed is 175 frames/s
  14. with a Boundary Recall of 0.797 and an Achievable Segmentation Accuracy of 0.944. The computational complexity is quadratic O(n2) and
  15. more suited to smaller images, but can still process a 2MP colour image faster than the SEEDS algorithm in OpenCV. The output is deterministic
  16. when the number of processing threads is fixed, and requires the source image to be in Lab colour format.
  17. */
  18. class CV_EXPORTS_W ScanSegment : public Algorithm
  19. {
  20. public:
  21. virtual ~ScanSegment();
  22. /** @brief Returns the actual superpixel segmentation from the last image processed using iterate.
  23. Returns zero if no image has been processed.
  24. */
  25. CV_WRAP virtual int getNumberOfSuperpixels() = 0;
  26. /** @brief Calculates the superpixel segmentation on a given image with the initialized
  27. parameters in the ScanSegment object.
  28. This function can be called again for other images without the need of initializing the algorithm with createScanSegment().
  29. This save the computational cost of allocating memory for all the structures of the algorithm.
  30. @param img Input image. Supported format: CV_8UC3. Image size must match with the initialized
  31. image size with the function createScanSegment(). It MUST be in Lab color space.
  32. */
  33. CV_WRAP virtual void iterate(InputArray img) = 0;
  34. /** @brief Returns the segmentation labeling of the image.
  35. Each label represents a superpixel, and each pixel is assigned to one superpixel label.
  36. @param labels_out Return: A CV_32UC1 integer array containing the labels of the superpixel
  37. segmentation. The labels are in the range [0, getNumberOfSuperpixels()].
  38. */
  39. CV_WRAP virtual void getLabels(OutputArray labels_out) = 0;
  40. /** @brief Returns the mask of the superpixel segmentation stored in the ScanSegment object.
  41. The function return the boundaries of the superpixel segmentation.
  42. @param image Return: CV_8UC1 image mask where -1 indicates that the pixel is a superpixel border, and 0 otherwise.
  43. @param thick_line If false, the border is only one pixel wide, otherwise all pixels at the border are masked.
  44. */
  45. CV_WRAP virtual void getLabelContourMask(OutputArray image, bool thick_line = false) = 0;
  46. };
  47. /** @brief Initializes a ScanSegment object.
  48. The function initializes a ScanSegment object for the input image. It stores the parameters of
  49. the image: image_width and image_height. It also sets the parameters of the F-DBSCAN superpixel
  50. algorithm, which are: num_superpixels, threads, and merge_small.
  51. @param image_width Image width.
  52. @param image_height Image height.
  53. @param num_superpixels Desired number of superpixels. Note that the actual number may be smaller
  54. due to restrictions (depending on the image size). Use getNumberOfSuperpixels() to
  55. get the actual number.
  56. @param slices Number of processing threads for parallelisation. Setting -1 uses the maximum number
  57. of threads. In practice, four threads is enough for smaller images and eight threads for larger ones.
  58. @param merge_small merge small segments to give the desired number of superpixels. Processing is
  59. much faster without merging, but many small segments will be left in the image.
  60. */
  61. CV_EXPORTS_W cv::Ptr<ScanSegment> createScanSegment(int image_width, int image_height, int num_superpixels, int slices = 8, bool merge_small = true);
  62. }} // namespace
  63. #endif