Jump to content

Livewire Segmentation Technique: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
PrimeBOT (talk | contribs)
m Replace magic links with templates per local RfC - BRFA
Added 3D extension of Livewire
Line 6: Line 6:


[[Image:Livewire-Bia.jpg|thumb|right|Example of livewire segmentation on a baby's photo]]
[[Image:Livewire-Bia.jpg|thumb|right|Example of livewire segmentation on a baby's photo]]
'''Livewire''', is a segmentation technique which allows a user to select regions of interest to be extracted quickly and accurately, using simple mouse clicks.<ref name="Baggio2007">BAGGIO, Daniel L´elis. GPGPU Based Image Segmentation Livewire Algorithm Implementation. 2007. 108f. Thesis of Master in Science – Technological Institute of Aeronautics, S˜ao Jos´e dos Campos. http://gpuwire.googlecode.com/files/Master%20Thesis%20-%20Updated%20February%2015th.pdf</ref> It is based on the [[Dijkstra's algorithm|lowest cost path algorithm]], by [[Edsger W. Dijkstra]]. Firstly Convolve the image with a Sobel filter to extract edges. Each pixel of the resulting image is a vertex of the graph and has edges going to the 4 pixels around it, as up, down, left, right. The edge costs are defined based on a cost function. In 1995, Eric N. Mortensen and William A. Barrett made some extension work on livewire segmentation tool, which is known as Intelligent Scissors.<ref name="MORTENSEN1995">MORTENSEN, E. N.; BARRETT, W. A. Intelligent scissors for image composition. In: SIGGRAPH ’95: Proceedings of the 22nd annual conference on Computer graphics and interactive techniques. New York, NY, USA: ACM Press, 1995. p.&nbsp;191–198. {{ISBN|0-89791-701-4}}.</ref>
'''Livewire''', is a segmentation technique which allows a user to select regions of interest to be extracted quickly and accurately, using simple mouse clicks.<ref name="Baggio2007">BAGGIO, Daniel L´elis. GPGPU Based Image Segmentation Livewire Algorithm Implementation. 2007. 108f. Thesis of Master in Science – Technological Institute of Aeronautics, S˜ao Jos´e dos Campos. http://gpuwire.googlecode.com/files/Master%20Thesis%20-%20Updated%20February%2015th.pdf</ref> It is based on the [[Dijkstra's algorithm|lowest cost path algorithm]], by [[Edsger W. Dijkstra]]. Firstly Convolve the image with a Sobel filter to extract edges. Each pixel of the resulting image is a vertex of the graph and has edges going to the 4 pixels around it, as up, down, left, right. The edge costs are defined based on a cost function. In 1995, Eric N. Mortensen and William A. Barrett made some extension work on livewire segmentation tool, which is known as Intelligent Scissors.<ref name="MORTENSEN1995">MORTENSEN, E. N.; BARRETT, W. A. Intelligent scissors for image composition. In: SIGGRAPH ’95: Proceedings of the 22nd annual conference on Computer graphics and interactive techniques. New York, NY, USA: ACM Press, 1995. p.&nbsp;191–198. {{ISBN|0-89791-701-4}}.</ref> In 2010, Leo Grady extended the Livewire algorithm to 3D segmentation.<ref name="GRADY2010">Leo Grady, “Minimal Surfaces Extend Shortest Path Segmentation Methods to 3D”, IEEE Trans. on Pattern Analysis and Machine Intelligence, Vol. 32, No. 2, pp. 321-334, Feb. 2010 http://leogrady.net/wp-content/uploads/2017/01/grady2010minimal.pdf </ref>


==Livewire Segmentation==
==Livewire Segmentation==
Line 44: Line 44:
'''''end'''''
'''''end'''''
'''''end'''''
'''''end'''''

==Extension to 3D==
In 2010, Leo Grady extended the Livewire algorithm to 3D.<ref name="GRADY2010"/> This extension treated the 2D Livewire algorithm as enabling a user to specify a 0-dimensional boundary (two points) and finding the minimal 1-dimensional coboundary (curve) connecting those points, where the minimum is defined in terms of image properties. In order to extend the algorithm to 3D, the user is instead asked to specify one or more 1-dimensional boundaries (closed curves) and the algorithm finds the minimal 2-dimensional coboundary (surface) bounded by the 1-dimensional curves, where the minimum surface is defined in terms of image properties. This 3D extension of Livewire leans heavily on concepts of [[Discrete Exterior Calculus]] to reinterpret the 2D Livewire algorithm from the standpoint of boundary/coboundary operators and then apply these concepts in 3D. An efficient algorithm for computing the 3D minimal surface is also provided in the Grady paper.


==See also==
==See also==

Revision as of 04:38, 20 July 2018

Example of livewire segmentation on a baby's photo

Livewire, is a segmentation technique which allows a user to select regions of interest to be extracted quickly and accurately, using simple mouse clicks.[1] It is based on the lowest cost path algorithm, by Edsger W. Dijkstra. Firstly Convolve the image with a Sobel filter to extract edges. Each pixel of the resulting image is a vertex of the graph and has edges going to the 4 pixels around it, as up, down, left, right. The edge costs are defined based on a cost function. In 1995, Eric N. Mortensen and William A. Barrett made some extension work on livewire segmentation tool, which is known as Intelligent Scissors.[2] In 2010, Leo Grady extended the Livewire algorithm to 3D segmentation.[3]

Livewire Segmentation

The user sets the starting point clicking on an image’s pixel, known as an anchor. Then, as he starts to move the mouse over other points, the smallest cost path is drawn from the anchor to the pixel where the mouse is over, changing itself if the user moves the mouse. If he wants to choose the path that is being displayed, he simply clicks the image again.

One can easily see in the right image, that the places where the user clicked to outline the desired region of interest are marked with a small square. It is also easy to see that the livewire has snapped on the image's borders.

Livewire Algorithm

Convolve the image with a Sobel filter to extract edges. Using this filtered image Create a graph using pixels as nodes with edges in four directions (up, down, left right).[1] Edges are weighted with features gathered from the sobel filter making it less costly to stay on an edge. Several different cost methods are possible but the most important is the gradient magnitude[1]

Live-Wire 2-D DP graph search algorithm in pseudocode [2]

    Input:
          s                       {Start (or seed) pixel.}
          l(q,r)                  {Local cost function for link between pixels q and r.} 
    Data Structures:
          L                       {List of active pixels sorted by total cost (initially empty).}
          N(q)                    {Neighborhood set of q (contains 8 neighbors of pixel).} 
          e(q)                    {Boolean function indicating if q has been expanded/processed.}
          g(q)                    {Total cost function from seed point to q.}
    Output: 
          p                       {Pointers from each pixel indicating the minimum cost path.}
    Algorithm:
          g(s) ← 0; L ← s;       {Initialize active list with zero cost seed pixel.}
          while L≠∅ do begin      {While still points to expand.}
                    q ← min(L);             {Remove minimum cost pixel q from active list.}
                    e(q) ←TRUE;             {Mark q as expanded (i.e., processed).}
                   for each r∈N(q) such that not e(r) do begin
                               gtmp ←g(q)+l(q,r);           {Compute total cost to neighbor.}
                               if r∈L and gtmp<g(r) then     {Remove higher cost neighbor’s from list.}
                                            r←L;                      
                               if r∉L then begin                  {If neighbor not on list, }
                                    g(r)←gtmp;                   {assign neighbor’s total cost, }
                                    p(r)←q;                      {set (or reset) back pointer, } 
                                    L←r;                         {and place on (or return to)  active list.} 
                               end                                
                    end 
           end

Extension to 3D

In 2010, Leo Grady extended the Livewire algorithm to 3D.[3] This extension treated the 2D Livewire algorithm as enabling a user to specify a 0-dimensional boundary (two points) and finding the minimal 1-dimensional coboundary (curve) connecting those points, where the minimum is defined in terms of image properties. In order to extend the algorithm to 3D, the user is instead asked to specify one or more 1-dimensional boundaries (closed curves) and the algorithm finds the minimal 2-dimensional coboundary (surface) bounded by the 1-dimensional curves, where the minimum surface is defined in terms of image properties. This 3D extension of Livewire leans heavily on concepts of Discrete Exterior Calculus to reinterpret the 2D Livewire algorithm from the standpoint of boundary/coboundary operators and then apply these concepts in 3D. An efficient algorithm for computing the 3D minimal surface is also provided in the Grady paper.


See also

References

  1. ^ a b c BAGGIO, Daniel L´elis. GPGPU Based Image Segmentation Livewire Algorithm Implementation. 2007. 108f. Thesis of Master in Science – Technological Institute of Aeronautics, S˜ao Jos´e dos Campos. http://gpuwire.googlecode.com/files/Master%20Thesis%20-%20Updated%20February%2015th.pdf
  2. ^ a b MORTENSEN, E. N.; BARRETT, W. A. Intelligent scissors for image composition. In: SIGGRAPH ’95: Proceedings of the 22nd annual conference on Computer graphics and interactive techniques. New York, NY, USA: ACM Press, 1995. p. 191–198. ISBN 0-89791-701-4.
  3. ^ a b Leo Grady, “Minimal Surfaces Extend Shortest Path Segmentation Methods to 3D”, IEEE Trans. on Pattern Analysis and Machine Intelligence, Vol. 32, No. 2, pp. 321-334, Feb. 2010 http://leogrady.net/wp-content/uploads/2017/01/grady2010minimal.pdf