Fast marching method
The fast marching method[1] is a numerical method created by James Sethian for solving boundary value problems of the Eikonal equation:
Typically, such a problem describes the evolution of a closed surface as a function of time  with speed
 with speed  in the normal direction at a point
 in the normal direction at a point  on the propagating surface. The speed function is specified, and the time at which the contour crosses a point
 on the propagating surface. The speed function is specified, and the time at which the contour crosses a point  is obtained by solving the equation. Alternatively,
 is obtained by solving the equation. Alternatively,  can be thought of as the minimum amount of time it would take to reach
 can be thought of as the minimum amount of time it would take to reach  starting from the point
 starting from the point  . Fast marching method takes advantage of this optimal control interpretation of the problem in order to build a solution outwards starting from the "known information", i.e. the boundary values.
. Fast marching method takes advantage of this optimal control interpretation of the problem in order to build a solution outwards starting from the "known information", i.e. the boundary values.
The algorithm is similar to Dijkstra's algorithm and uses the fact that information only flows outward from the seeding area. This problem is a special case of level set methods. More general algorithms exist but are normally slower.
Extensions to non-flat (triangulated) domains solving:
was introduced by Ron Kimmel and James Sethian.
- 
 Maze as speed function shortest path 
- 
 Distance map multi-stencils with random source points 
Algorithm
First, assume that the domain has been discretized into a mesh. We will refer to meshpoints as nodes. Each node  has a corresponding value
 has a corresponding value  .
.
The algorithm works just like Dijkstra's algorithm but differs in how the value of node's is calculated. In Dijkstra's algorithm a node's value is calculated using a single one of the neighboring nodes. However, in solving the PDE in  between
 between  and
 and  of the neighboring nodes are used.
 of the neighboring nodes are used.
Nodes are labeled as far (not yet visited), considered (visited and value tentatively assigned), and accepted (visited and value permanently assigned).
-  Assign every node  the value of the value of and label them as far; for all nodes and label them as far; for all nodes set set and label and label as accepted. as accepted.
-  For every accepted node  , use the Eikonal update formula to calculate a new value for , use the Eikonal update formula to calculate a new value for . If . If then set then set and label and label as considered. as considered.
-  Let  be the considered node with the smallest value be the considered node with the smallest value . Label . Label as accepted. as accepted.
-  For every neighbor  of of that is not-accepted, calculate a tentative value that is not-accepted, calculate a tentative value . .
-  If  then set then set . If . If was labeled as far, update the label to considered. was labeled as far, update the label to considered.
- If there exists a considered node, return to step 3. Otherwise, terminate.
See also
- Level set method
- Fast sweeping method
- Bellman-Ford algorithm
External links
- Djikstra-like Methods for the Eikonal Equation J.N. Tsitsiklis, 1995
- The Fast Marching Method and its Applications by James A. Sethian
- Multi-Stencils Fast Marching Methods
- Multi-Stencils Fast Marching Matlab Implementation
- Implementation Details of the Fast Marching Methods
- Generalized Fast Marching method by Forcadel et al. [2008] for applications in image segmentation.
- See Chapter 8 in Design and Optimization of Nano-Optical Elements by Coupling Fabrication to Optical Behavior
Notes
- ↑ J.A. Sethian. A Fast Marching Level Set Method for Monotonically Advancing Fronts, Proc. Nat. Acad. Sci., 93, 4, pp.1591--1595, 1996.


