interpolate
Interpolate poses along planned vehicle path
Syntax
Description
interpolates along the length of a reference path, returning transition poses. For more
information, see Transition Poses.poses
= interpolate(refPath
)
[
also returns the motion directions of the vehicle at each pose, using inputs from any of the
preceding syntaxes.poses
,directions
] = interpolate(___)
Examples
Plan Path and Check Its Validity
Plan a vehicle path through a parking lot by using the optimal rapidly exploring random tree (RRT*) algorithm. Check that the path is valid, and then plot the transition poses along the path.
Load a costmap of a parking lot. Plot the costmap to see the parking lot and inflated areas for the vehicle to avoid.
data = load('parkingLotCostmap.mat');
costmap = data.parkingLotCostmap;
plot(costmap)
Define start and goal poses for the vehicle as [x, y, Θ] vectors. World units for the (x,y) locations are in meters. World units for the Θ orientation angles are in degrees.
startPose = [4, 4, 90]; % [meters, meters, degrees]
goalPose = [30, 13, 0];
Use a pathPlannerRRT
object to plan a path from the start pose to the goal pose.
planner = pathPlannerRRT(costmap); refPath = plan(planner,startPose,goalPose);
Check that the path is valid.
isPathValid = checkPathValidity(refPath,costmap)
isPathValid = logical
1
Interpolate the transition poses along the path.
transitionPoses = interpolate(refPath);
Plot the planned path and the transition poses on the costmap.
hold on plot(refPath,'DisplayName','Planned Path') scatter(transitionPoses(:,1),transitionPoses(:,2),[],'filled', ... 'DisplayName','Transition Poses') hold off
Plan Path and Interpolate Along Path
Plan a vehicle path through a parking lot by using the rapidly exploring random tree (RRT*) algorithm. Interpolate the poses of the vehicle at points along the path.
Load a costmap of a parking lot. Plot the costmap to see the parking lot and inflated areas for the vehicle to avoid.
data = load('parkingLotCostmap.mat');
costmap = data.parkingLotCostmap;
plot(costmap)
Define start and goal poses for the vehicle as [
x, y, Θ]
vectors. World units for the (x,y) locations are in meters. World units for the Θ orientation angles are in degrees.
startPose = [4, 4, 90]; % [meters, meters, degrees]
goalPose = [30, 13, 0];
Use a pathPlannerRRT
object to plan a path from the start pose to the goal pose.
planner = pathPlannerRRT(costmap); refPath = plan(planner,startPose,goalPose);
Interpolate the vehicle poses every 1 meter along the entire path.
lengths = 0 : 1 : refPath.Length; poses = interpolate(refPath,lengths);
Plot the interpolated poses on the costmap.
plot(costmap) hold on scatter(poses(:,1),poses(:,2),'DisplayName','Interpolated Poses') hold off
Input Arguments
refPath
— Planned vehicle path
driving.Path
object
Planned vehicle path, specified as a driving.Path
object.
lengths
— Points along length of path
real-valued vector
Points along the length of the path, specified as a real-valued vector. Values must
be in the range from 0 to the length of the path, as determined by the Length
property of refPath
. The
interpolate
function interpolates poses at these specified
points. lengths
is in world units, such as meters.
Example: poses = interpolate(refPath,0:0.1:refPath.Length)
interpolates poses every 0.1 meter along the entire length of the path.
Output Arguments
poses
— Vehicle poses
m-by-3 matrix of [x, y,
Θ] vectors
Vehicle poses along the path, returned as an m-by-3 matrix of [x, y, Θ] vectors. m is the number of returned poses.
x and y specify the location of the vehicle in world units, such as meters. Θ specifies the orientation angle of the vehicle in degrees.
poses
always includes the transition poses, even if you
interpolate only at specified points along the path. If you do not specify the
lengths
input argument, then poses
includes
only the transition poses.
directions
— Motion directions
m-by-1 vector of 1s (forward motion) and –1s (reverse
motion)
Motion directions of vehicle poses, returned as an m-by-1 vector
of 1s (forward motion) and –1s (reverse motion). m is the number of
returned poses. Each element of directions
corresponds to a row of
poses
.
More About
Transition Poses
A path is composed of multiple segments that are combinations of
motions (for example, left turn, straight, and right turn). Transition
poses are vehicle poses corresponding to the end of one motion and the
beginning of another motion. They represent points along the path corresponding to a change
in the direction or orientation of the vehicle. The interpolate
function always returns transition poses, even if you interpolate only at specified points
along the path.
The path length between transition poses is given by the
MotionLengths
property of the path segments. For example, consider
the following path, which is a driving.Path
object composed of a single Dubins path segment. This segment consists of three motions, as
described by the MotionLengths
and MotionTypes
properties of the segment.
The interpolate
function interpolates the following transition
poses in this order:
The initial pose of the vehicle,
StartPose
.The pose after the vehicle turns left (
"L"
) for 4.39 meters at its maximum steering angle.The pose after the vehicle goes straight (
"S"
) for 6.32 meters.The pose after the vehicle turns right (
"R"
) for 4.39 meters at its maximum steering angle. This pose is also the goal pose, because it is the last pose of the entire path.
The plot shows these transition poses, which are [x, y, Θ] vectors. x and y specify the location of the vehicle in world units, such as meters. Θ specifies the orientation angle of the vehicle in degrees.
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using MATLAB® Coder™.
Version History
Introduced in R2018b
See Also
Functions
Objects
Topics
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)