forked from SleipnirGroup/Choreo
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2133a6d
commit 7fa7fc9
Showing
2 changed files
with
222 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
// Copyright (c) TrajoptLib contributors | ||
|
||
#include <numbers> | ||
|
||
#include <trajopt/DifferentialTrajectoryGenerator.hpp> | ||
|
||
// SwervePathBuilder is used to build paths that are optimized into full | ||
// trajectories. | ||
// | ||
// "Wpt" stands for waypoint, an instantaneous moment in the path where certain | ||
// constrains on the robot's state are applied. | ||
// | ||
// "Sgmt" is the abbreviation for segments, the continuum of state between | ||
// waypoints where constraints can also be applied. | ||
|
||
int main() { | ||
trajopt::DifferentialDrivetrain differentialDrivetrain{.mass = 45, | ||
.moi = 6, | ||
.trackwidth = 0.6, | ||
.left = | ||
{ | ||
0.08, | ||
70, | ||
5, | ||
}, | ||
.right = { | ||
0.08, | ||
70, | ||
5, | ||
}}; | ||
|
||
trajopt::LinearVelocityMaxMagnitudeConstraint zeroLinearVelocity{0.0}; | ||
trajopt::AngularVelocityMaxMagnitudeConstraint zeroAngularVelocity{0.0}; | ||
|
||
// Example 1: Differential, one meter forward motion profile | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
path.PoseWpt(0, 0.0, 0.0, 0.0); | ||
path.PoseWpt(1, 1.0, 0.0, 0.0); | ||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(1, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 2: Differential, basic curve | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
path.PoseWpt(0, 1.0, 1.0, -std::numbers::pi / 2); | ||
path.PoseWpt(1, 2.0, 0.0, 0.0); | ||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(1, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 3: Differential, three waypoints | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
path.PoseWpt(0, 0.0, 0.0, std::numbers::pi / 2); | ||
path.PoseWpt(1, 1.0, 1.0, 0.0); | ||
path.PoseWpt(2, 2.0, 0.0, std::numbers::pi / 2); | ||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(1, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40, 40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 4: Differential, ending velocity | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
path.PoseWpt(0, 0.0, 0.0, 0.0); | ||
path.PoseWpt(1, 0.0, 1.0, 0.0); | ||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 5: Differential, circle obstacle | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
path.PoseWpt(0, 0.0, 0.0, 0.0); | ||
trajopt::Obstacle obstacle{// Radius of 0.1 | ||
.safetyDistance = 0.1, | ||
.points = {{0.5, 0.5}}}; | ||
path.SgmtObstacle(0, 1, obstacle); | ||
path.PoseWpt(1, 1.0, 0.0, 0.0); | ||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(1, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 6: Approach a pick up station at a certain direction | ||
{ | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
|
||
// Starting position | ||
path.PoseWpt(0, 0.0, 0.0, 0.0); | ||
|
||
// Align towards the station one meter behind | ||
path.PoseWpt(1, 1.0, 1.0, std::numbers::pi / 2); | ||
path.WptConstraint(1, zeroAngularVelocity); | ||
path.WptConstraint( | ||
1, trajopt::LinearVelocityDirectionConstraint{std::numbers::pi / 2}); | ||
|
||
// Go up to the station. In practice, the optimizer will still end up | ||
// aligning the heading without the pose constraint since it's most optimal. | ||
path.TranslationWpt(2, 1.0, 2.0); | ||
|
||
// Realign behind the station | ||
path.PoseWpt(3, 1.0, 1.0, std::numbers::pi / 2); | ||
path.WptConstraint(3, zeroAngularVelocity); | ||
path.WptConstraint( | ||
3, trajopt::LinearVelocityDirectionConstraint{std::numbers::pi / 2}); | ||
|
||
// Ending position | ||
path.PoseWpt(4, 2.0, 0.0, std::numbers::pi); | ||
|
||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(4, zeroLinearVelocity); | ||
path.ControlIntervalCounts({40, 30, 30, 40}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
|
||
// Example 7: Circular path with a point-point constraint | ||
{ | ||
// Note that forcing a circular path is not a common problem in FRC. This | ||
// example is only here to demonstrate how various constraints work. | ||
trajopt::DifferentialPathBuilder path; | ||
path.SetDrivetrain(differentialDrivetrain); | ||
|
||
path.PoseWpt(0, 0.0, 0.0, 0.0); | ||
path.SgmtConstraint( | ||
0, 1, | ||
trajopt::PointPointConstraint{// Robot point -- center of robot | ||
{0.0, 0.0}, | ||
// Field point around which to orbit | ||
{1.0, 0.0}, | ||
// Stay 1 m away to force circular motion | ||
1.0}); | ||
|
||
// Tell optimizer to go in +y direction rather than -y | ||
path.WptInitialGuessPoint(0, {0.0, 0.0, 0.0}); | ||
|
||
path.PoseWpt(1, 2.0, 0.0, 0.0); | ||
|
||
path.WptConstraint(0, zeroLinearVelocity); | ||
path.WptConstraint(1, zeroLinearVelocity); | ||
path.ControlIntervalCounts({30}); | ||
|
||
trajopt::DifferentialTrajectoryGenerator generator{path}; | ||
[[maybe_unused]] | ||
auto solution = generator.Generate(true); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters