Skip to content
/ grabcut Public

Grabcut implementation, which is color-based foreground-background segmentation. It's based on my 2011 uni project but rewritten and improved.

Notifications You must be signed in to change notification settings

rAum/grabcut

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Grabcut

This is work in progress of a rewrite of my uni project I did in 2010 for image processing class to not use (ancient!) OpenCV 1.x and use Eigen. It probably is not optimal and might be buggy.

Grabcut algorithm

The grabcut algorithm works by first split foreground/background areas into GMM color models (I use orchard-bauman clustering method). Next the maxflow/mincut algorithm is used to refine edges. Lastly, the GMM is then refined by using new segmentation mask and maxflow/mincut is applied again - we continue that for n steps or until convergence.

Example

  1. Input image
  2. User rectangle selection
  3. Running grabcut (1 iteration) grabcut

Building

At the moment all batteries are included for library/tests but it requires OpenCV for user-facing app.

cmake -B build -DBUILD_TESTS=ON -DCMAKE_BUILD_TYPE=Release -DBUILD_GRABCUT_APPS=OFF
cmake --build build -j

for building library and tests, and if you have installed OpenCV findable by CMake:

cmake -B build -DCMAKE_BUILD_TYPE=Release -DBUILD_GRABCUT_APPS=ON
cmake --build build -j

which will build app which runs OpenCV and this implementation for comparision (this is slower and results may vary)

build/apps/run_grabcut <img.jpg|png>

Comparision with OpenCV

A few examples to compare with OpenCV (5 iterations for each implementation):

image image

Flower: image

People:

image

people

image

image

About

Grabcut implementation, which is color-based foreground-background segmentation. It's based on my 2011 uni project but rewritten and improved.

Topics

Resources

Stars

Watchers

Forks