Skip to content

Commit

Permalink
Replace trajectories page on Ramsete with LTV Unicycle
Browse files Browse the repository at this point in the history
RamseteController was deprecated in wpilibsuite/allwpilib#6494
Does 1 part of #2651

Signed-off-by: Jade Turner <spacey-sooty@proton.me>
  • Loading branch information
spacey-sooty committed Oct 16, 2024
1 parent 2c1ca60 commit ac12f3e
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 32 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,6 @@ This section describes WPILib support for generating parameterized spline trajec
constraints
manipulating-trajectories
transforming-trajectories
ramsete
ltv
holonomic
troubleshooting
Original file line number Diff line number Diff line change
@@ -1,42 +1,24 @@
# Ramsete Controller
The Ramsete Controller is a trajectory tracker that is built in to WPILib. This tracker can be used to accurately track trajectories with correction for minor disturbances.
# LTV Unicycle Controller
The LTV Unicycle Controller is a trajectory tracker that is built in to WPILib. This tracker can be used to accurately track trajectories with correction for minor disturbances.

## Constructing the Ramsete Controller Object
The Ramsete controller should be initialized with two gains, namely ``b`` and ``zeta``. Larger values of ``b`` make convergence more aggressive like a proportional term whereas larger values of ``zeta`` provide more damping in the response. These controller gains only dictate how the controller will output adjusted velocities. It does NOT affect the actual velocity tracking of the robot. This means that these controller gains are generally robot-agnostic.

.. note:: Gains of ``2.0`` and ``0.7`` for ``b`` and ``zeta`` have been tested repeatedly to produce desirable results when all units were in meters. As such, a zero-argument constructor for ``RamseteController`` exists with gains defaulted to these values.
## Constructing the LTV Unicycle Controller Object
The LTV controller should be initialized with two parameters, `dt` and `maxVelocity`. `dt` represents the timestep used in calculations and `maxVelocity` should be the max velocity your robot can achieve.

.. tab-set-code::
```java
// Using the default constructor of RamseteController. Here
// the gains are initialized to 2.0 and 0.7.
RamseteController controller1 = new RamseteController();
// Using the secondary constructor of RamseteController where
// the user can choose any other gains.
RamseteController controller2 = new RamseteController(2.1, 0.8);
LTVUnicycle controller = new LTVUnicycleController(0.2, 9);
```

```c++
// Using the default constructor of RamseteController. Here
// the gains are initialized to 2.0 and 0.7.
frc::RamseteController controller1;
// Using the secondary constructor of RamseteController where
// the user can choose any other gains.
frc::RamseteController controller2{2.1, 0.8};
frc::LTVUnicycleController controller{0.2_s, 9_mps};
```

```python
from wpimath.controller import RamseteController
# Using the default constructor of RamseteController. Here
# the gains are initialized to 2.0 and 0.7.
controller1 = RamseteController()
# Using the secondary constructor of RamseteController where
# the user can choose any other gains.
controller2 = RamseteController(2.1, 0.8)
controller = LTVUnicycleController(0.2, 9)
```

## Getting Adjusted Velocities
The Ramsete controller returns "adjusted velocities" so that the when the robot tracks these velocities, it accurately reaches the goal point. The controller should be updated periodically with the new goal. The goal comprises of a desired pose, desired linear velocity, and desired angular velocity. Furthermore, the current position of the robot should also be updated periodically. The controller uses these four arguments to return the adjusted linear and angular velocity. Users should command their robot to these linear and angular velocities to achieve optimal trajectory tracking.
The LTV Unicycle controller returns "adjusted velocities" so that the when the robot tracks these velocities, it accurately reaches the goal point. The controller should be updated periodically with the new goal. The goal comprises of a desired pose, desired linear velocity, and desired angular velocity. Furthermore, the current position of the robot should also be updated periodically. The controller uses these four arguments to return the adjusted linear and angular velocity. Users should command their robot to these linear and angular velocities to achieve optimal trajectory tracking.

.. note:: The "goal pose" represents the position that the robot should be at a particular timestep when tracking the trajectory. It does NOT represent the final endpoint of the trajectory.

Expand Down Expand Up @@ -90,6 +72,3 @@ The returned adjusted speeds can be converted to usable speeds using the kinemat

Because these new left and right velocities are still speeds and not voltages, two PID Controllers, one for each side may be used to track these velocities. Either the WPILib PIDController ([C++](https://github.wpilib.org/allwpilib/docs/development/cpp/classfrc_1_1_p_i_d_controller.html), [Java](https://github.wpilib.org/allwpilib/docs/development/java/edu/wpi/first/math/controller/PIDController.html), :external:py:class:`Python <wpimath.controller.PIDController>`) can be used, or the Velocity PID feature on smart motor controllers such as the TalonSRX and the SPARK MAX can be used.

## Ramsete in the Command-Based Framework
For the sake of ease for users, a ``RamseteCommand`` class is built in to WPILib. For a full tutorial on implementing a path-following autonomous using RamseteCommand, see :ref:`docs/software/pathplanning/trajectory-tutorial/index:Trajectory Tutorial`.

2 changes: 1 addition & 1 deletion source/docs/software/pathplanning/index.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Path Planning

Path Planning is the process of creating and following trajectories. These paths use the WPILib trajectory APIs for generation and a :ref:`Ramsete Controller <docs/software/advanced-controls/trajectories/ramsete:Ramsete Controller>` for following. This section highlights the process of characterizing your robot for system identification, trajectory following and usage of PathWeaver. Users may also want to read the :ref:`generic trajectory following documents <docs/software/advanced-controls/trajectories/index:Trajectory Generation and Following with WPILib>` for additional information about the API and non-commandbased usage.
Path Planning is the process of creating and following trajectories. These paths use the WPILib trajectory APIs for generation and a :ref:`LTV Unicycle Controller <docs/software/advanced-controls/trajectories/ltv:LTV Unicycle Controller>` for following. This section highlights the process of characterizing your robot for system identification, trajectory following and usage of PathWeaver. Users may also want to read the :ref:`generic trajectory following documents <docs/software/advanced-controls/trajectories/index:Trajectory Generation and Following with WPILib>` for additional information about the API and non-commandbased usage.

## Notice on Swerve Support

Expand Down
1 change: 0 additions & 1 deletion source/redirects.txt
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@
"docs/software/advanced-control/introduction/tuning-pid-controller.rst" "docs/software/advanced-controls/introduction/tuning-pid-controller.rst"
"docs/software/advanced-control/trajectories/index.rst" "docs/software/advanced-controls/trajectories/index.rst"
"docs/software/advanced-control/trajectories/manipulating-trajectories.rst" "docs/software/advanced-controls/trajectories/manipulating-trajectories.rst"
"docs/software/advanced-control/trajectories/ramsete.rst" "docs/software/advanced-controls/trajectories/ramsete.rst"
"docs/software/advanced-control/trajectories/transforming-trajectories.rst" "docs/software/advanced-controls/trajectories/transforming-trajectories.rst"
"docs/software/advanced-control/trajectories/troubleshooting.rst" "docs/software/advanced-controls/trajectories/troubleshooting.rst"
"docs/software/vision-processing/grip/reading-array-values-published-by-networktables.rst" "docs/software/networktables/reading-array-values-published-by-networktables.rst"
Expand Down

0 comments on commit ac12f3e

Please sign in to comment.