Watershed algorithm
OpenCV comes with default implementations of watershed algorithms, at https://docs.opencv.org/trunk/d3/db4/tutorial_py_watershed.html, which theory says that any grayscale image can be viewed as a topographic surface where high intensity denotes peaks and hills, while low intensity denotes valleys. This algorithm is pretty famous and there are a lot of implementations available out there.
Consider the following image:
data:image/s3,"s3://crabby-images/f2291/f22917694838579234779e4fca25fa483bb1a648" alt=""
Let's select the regions depending on their topographic surface:
data:image/s3,"s3://crabby-images/e1402/e1402761c0393d931311d461e5e315e8fb236322" alt=""
If you run the watershed algorithm on this, the output will look something like this:
data:image/s3,"s3://crabby-images/2c04e/2c04e32dfb6739f082132c9c7a0593878275f4ec" alt=""
Sample code can be found on the link given previously, along with many other applications of the watershed algorithm.Â