WPILibC++ 2025.2.1
Loading...
Searching...
No Matches
frc::SplineHelper Class Reference

Helper class that is used to generate cubic and quintic splines from user provided waypoints. More...

#include <frc/spline/SplineHelper.h>

Static Public Member Functions

static wpi::array< Spline< 3 >::ControlVector, 2 > CubicControlVectorsFromWaypoints (const Pose2d &start, const std::vector< Translation2d > &interiorWaypoints, const Pose2d &end)
 Returns 2 cubic control vectors from a set of exterior waypoints and interior translations.
 
static std::vector< QuinticHermiteSplineQuinticSplinesFromWaypoints (const std::vector< Pose2d > &waypoints)
 Returns quintic splines from a set of waypoints.
 
static std::vector< CubicHermiteSplineCubicSplinesFromControlVectors (const Spline< 3 >::ControlVector &start, std::vector< Translation2d > waypoints, const Spline< 3 >::ControlVector &end)
 Returns a set of cubic splines corresponding to the provided control vectors.
 
static std::vector< QuinticHermiteSplineQuinticSplinesFromControlVectors (const std::vector< Spline< 5 >::ControlVector > &controlVectors)
 Returns a set of quintic splines corresponding to the provided control vectors.
 
static std::vector< QuinticHermiteSplineOptimizeCurvature (const std::vector< QuinticHermiteSpline > &splines)
 Optimizes the curvature of 2 or more quintic splines at knot points.
 

Detailed Description

Helper class that is used to generate cubic and quintic splines from user provided waypoints.

Member Function Documentation

◆ CubicControlVectorsFromWaypoints()

static wpi::array< Spline< 3 >::ControlVector, 2 > frc::SplineHelper::CubicControlVectorsFromWaypoints ( const Pose2d & start,
const std::vector< Translation2d > & interiorWaypoints,
const Pose2d & end )
inlinestatic

Returns 2 cubic control vectors from a set of exterior waypoints and interior translations.

Parameters
startThe starting pose.
interiorWaypointsThe interior waypoints.
endThe ending pose.
Returns
2 cubic control vectors.

◆ CubicSplinesFromControlVectors()

static std::vector< CubicHermiteSpline > frc::SplineHelper::CubicSplinesFromControlVectors ( const Spline< 3 >::ControlVector & start,
std::vector< Translation2d > waypoints,
const Spline< 3 >::ControlVector & end )
inlinestatic

Returns a set of cubic splines corresponding to the provided control vectors.

The user is free to set the direction of the start and end point. The directions for the middle waypoints are determined automatically to ensure continuous curvature throughout the path.

The derivation for the algorithm used can be found here: https://www.uio.no/studier/emner/matnat/ifi/nedlagte-emner/INF-MAT4350/h08/undervisningsmateriale/chap7alecture.pdf

Parameters
startThe starting control vector.
waypointsThe middle waypoints. This can be left blank if you only wish to create a path with two waypoints.
endThe ending control vector.
Returns
A vector of cubic hermite splines that interpolate through the provided waypoints.

◆ OptimizeCurvature()

static std::vector< QuinticHermiteSpline > frc::SplineHelper::OptimizeCurvature ( const std::vector< QuinticHermiteSpline > & splines)
inlinestatic

Optimizes the curvature of 2 or more quintic splines at knot points.

Overall, this reduces the integral of the absolute value of the second derivative across the set of splines.

Parameters
splinesA vector of un-optimized quintic splines.
Returns
A vector of optimized quintic splines.

◆ QuinticSplinesFromControlVectors()

static std::vector< QuinticHermiteSpline > frc::SplineHelper::QuinticSplinesFromControlVectors ( const std::vector< Spline< 5 >::ControlVector > & controlVectors)
inlinestatic

Returns a set of quintic splines corresponding to the provided control vectors.

The user is free to set the direction of all waypoints. Continuous curvature is guaranteed throughout the path.

Parameters
controlVectorsThe control vectors.
Returns
A vector of quintic hermite splines that interpolate through the provided waypoints.

◆ QuinticSplinesFromWaypoints()

static std::vector< QuinticHermiteSpline > frc::SplineHelper::QuinticSplinesFromWaypoints ( const std::vector< Pose2d > & waypoints)
inlinestatic

Returns quintic splines from a set of waypoints.

Parameters
waypointsThe waypoints
Returns
List of quintic splines.

The documentation for this class was generated from the following file: