For the decoupled approach in this section, assume that 
 ,
which means there are only velocity constraints, as covered in Section
13.1.  The system may be specified as
,
which means there are only velocity constraints, as covered in Section
13.1.  The system may be specified as 
 or
implicitly as a set of constraints of the form
 or
implicitly as a set of constraints of the form 
 .
The ideas in this section can easily be extended to phase spaces.  The
method given here was developed primarily by Laumond (see
[596]) and was also applied to the simple car of Section
13.1.2 in [587]; other applications of the method
are covered in [596].
.
The ideas in this section can easily be extended to phase spaces.  The
method given here was developed primarily by Laumond (see
[596]) and was also applied to the simple car of Section
13.1.2 in [587]; other applications of the method
are covered in [596].
An outline of the plan-and-transform approach is shown in Figure
14.21.  In the first step, a collision-free path 
![$ \tau: [0,1] \rightarrow {\cal C}_{free}$](img1368.gif) is computed by ignoring differential
constraints.  The path is then iteratively modified until it satisfies
the constraints.  In each iteration, a subinterval
 is computed by ignoring differential
constraints.  The path is then iteratively modified until it satisfies
the constraints.  In each iteration, a subinterval 
![$ [s_1,s_2]
\subseteq [0,1]$](img6408.gif) is selected by specifying some
 is selected by specifying some 
![$ s_1,s_2 \in [0,1]$](img2544.gif) so that
so that  .  These points may be chosen using random
sequences or may be chosen deterministically.  The approach may use
binary subdivision to refine intervals and gradually improve the
resolution on
.  These points may be chosen using random
sequences or may be chosen deterministically.  The approach may use
binary subdivision to refine intervals and gradually improve the
resolution on ![$ [0,1]$](img1000.gif) over the iterations.
 over the iterations.
For each chosen interval ![$ [s_1,s_2]$](img6409.gif) , an LPM is used to compute a path segment
, an LPM is used to compute a path segment
![$ \gamma: [0,1] \rightarrow {\cal C}_{free}$](img6410.gif) that satisfies the conditions
 that satisfies the conditions
 and
 and 
 .  It might be the
case that the LPM fails because it cannot connect the two
configurations or a collision may occur.  In this case, another
subinterval is chosen, and the process repeats.  Each time the
LPM succeeds,
.  It might be the
case that the LPM fails because it cannot connect the two
configurations or a collision may occur.  In this case, another
subinterval is chosen, and the process repeats.  Each time the
LPM succeeds,
 is updated to
 is updated to  as
 as
| ![$\displaystyle \tau'(s) = \left\{ \begin{array}{ll} \tau(s) & \mbox{ if $s < s_1...
... if $s \in [s_1,s_2]$} \\ \tau(s) & \mbox{ if $s > s_2$.} \\ \end{array}\right.$](img6413.gif) | (14.30) | 
 reparameterizes it to run from
 reparameterizes it to run from  to
 to
 , instead of 0 to
, instead of 0 to  .
.
 that might be
computed by a motion planning algorithm that ignores differential
constraints.  Two sharp corners cannot be traversed by the car.
Suppose that
 that might be
computed by a motion planning algorithm that ignores differential
constraints.  Two sharp corners cannot be traversed by the car.
Suppose that  and
 and  are chosen at random, and appear at the
locations shown in Figure 14.22.  The portion of
 are chosen at random, and appear at the
locations shown in Figure 14.22.  The portion of
 between
 between  and
 and  needs to be replaced by a
path that can be executed by the Dubins car.  Note that matching the
orientations at
 needs to be replaced by a
path that can be executed by the Dubins car.  Note that matching the
orientations at  and
 and  is important because they
are part of the configuration.
 is important because they
are part of the configuration.
A replacement path  is shown in Figure 14.23.
This is obtained by implementing the following LPM.  For the Dubins car, a path
between any configurations can be found by drawing circles at the
starting and stopping configurations as shown in the figure.  Each
circle corresponds to the sharpest possible left turn or right turn.
It is straightforward to find a line that is tangent to one circle
from each configuration and also matches the direction of flow for the
car (the circles are like one-way streets).  Using
 is shown in Figure 14.23.
This is obtained by implementing the following LPM.  For the Dubins car, a path
between any configurations can be found by drawing circles at the
starting and stopping configurations as shown in the figure.  Each
circle corresponds to the sharpest possible left turn or right turn.
It is straightforward to find a line that is tangent to one circle
from each configuration and also matches the direction of flow for the
car (the circles are like one-way streets).  Using  , the path
, the path
 is updated to obtain
 is updated to obtain  , which is shown in Figure
14.24, and satisfies the differential constraints for
the Dubins car.  This problem was very simple, and in practice dozens
of iterations may be necessary to replace path segments.  Also, if
randomization is used, then intervals of the form
, which is shown in Figure
14.24, and satisfies the differential constraints for
the Dubins car.  This problem was very simple, and in practice dozens
of iterations may be necessary to replace path segments.  Also, if
randomization is used, then intervals of the form ![$ [0,s]$](img6417.gif) and
 and ![$ [s,1]$](img6418.gif) must not be neglected.
must not be neglected.
| ![\includegraphics[width=5.0truein]{figs/dubinspath2.eps}](img6419.gif) | 
 
 
Example 14.5 seemed easy because of the existence of a
simple local planner.  Also, there were no obstacles.  Imagine that
 instead traveled through a narrow, zig-zagging corridor.  In
this case, a solution might not even exist because of sharp corners
that cannot be turned by the Dubins car.  If there had been an
single obstacle that happened to intersect the loop in Figure
14.24, then the replacement would have failed.  In
general, there is no guarantee that the replacement segment is
collision-free.  It is important for the LPM to construct path segments that are as
close as possible to the original path.  For the Dubins car,
this is not possible in many cases.  For example, moving the Dubins
car a small distance backward requires moving along the circles shown
in Figure 14.23.  Even as the distance between two
configurations is reduced, the distance that the car needs to travel
does not approach zero.  This is true even if the shortest possible
paths are used for the Dubins car.
 instead traveled through a narrow, zig-zagging corridor.  In
this case, a solution might not even exist because of sharp corners
that cannot be turned by the Dubins car.  If there had been an
single obstacle that happened to intersect the loop in Figure
14.24, then the replacement would have failed.  In
general, there is no guarantee that the replacement segment is
collision-free.  It is important for the LPM to construct path segments that are as
close as possible to the original path.  For the Dubins car,
this is not possible in many cases.  For example, moving the Dubins
car a small distance backward requires moving along the circles shown
in Figure 14.23.  Even as the distance between two
configurations is reduced, the distance that the car needs to travel
does not approach zero.  This is true even if the shortest possible
paths are used for the Dubins car.
What property should an LPM have to ensure resolution completeness of the
plan-and-transform approach?  A sufficient condition is given in
[596].  Let  denote a metric on
 denote a metric on  .  An LPM is
said to satisfy the topological property if and only if the
following statement holds: For any
.  An LPM is
said to satisfy the topological property if and only if the
following statement holds: For any 
 , there exists some
, there exists some
 such that for any pair
 such that for any pair 
 having
 having
 implies that
 implies that 
 for
all
 for
all 
![$ s
\in [0,1]$](img756.gif) .  If an LPM satisfies the topological property, then any
collision-free path through
.  If an LPM satisfies the topological property, then any
collision-free path through 
 can be transformed into one that
satisfies the differential constraints.  Suppose that a path
 can be transformed into one that
satisfies the differential constraints.  Suppose that a path  has some clearance of at least
has some clearance of at least  in
 in 
 .  By dividing
the domain of
.  By dividing
the domain of  into intervals so that the change in
 into intervals so that the change in  is no
more than
 is no
more than  over each interval, then the LPM will produce
collision-free path segments for replacement.
 over each interval, then the LPM will produce
collision-free path segments for replacement.
It turns out that for the Reeds-Shepp car (which has reverse) such an LPM can be designed because it is small-time locally controllable, a property that will be covered in Sections 15.1.3 and 15.4. In general, many techniques from Chapter 15 may be useful for analyzing and designing effective LPMs.
An interesting adaptation of the plan-and-transform approach has been
developed for problems that involve  implicit constraints of the
form
 implicit constraints of the
form 
 .  An outline of the multi-level approach, which was
introduced in [859], is shown in Figure
14.25 (a similar approach was also introduced in
[333]).  The idea is to sort the
.  An outline of the multi-level approach, which was
introduced in [859], is shown in Figure
14.25 (a similar approach was also introduced in
[333]).  The idea is to sort the  constraints into a
sequence and introduce them one at a time.  Initially, a path is
planned that ignores the constraints.  This path is first transformed
to satisfy
 constraints into a
sequence and introduce them one at a time.  Initially, a path is
planned that ignores the constraints.  This path is first transformed
to satisfy 
 and avoid collisions by using the
plan-and-transform method of Figure 14.21.  If successful,
then the resulting path is transformed into one that is collision-free
and satisfies both
 and avoid collisions by using the
plan-and-transform method of Figure 14.21.  If successful,
then the resulting path is transformed into one that is collision-free
and satisfies both 
 and
 and 
 .  This
process repeats by adding one constraint each time, until either the
method fails or all
.  This
process repeats by adding one constraint each time, until either the
method fails or all  constraints have been taken into account.
 constraints have been taken into account.
Steven M LaValle 2020-08-14