class final
UnicycleTrajectoryGeneratorUnicycleTrajectoryGenerator is a class that generates reference trajectories for humanoid robots.
Every time that the advance() member function is called, the Generator:
- First checks if it is time to generate a new trajectory. In this case, it deploys the BipedalLocomotion::
Planners:: UnicycleTrajectoryPlanner to plan this new trajectory. - Then, it checks if it is time to merge the current trajectory with the last one computed by the UnicycleTrajectoryPlanner. In this case, it merges the two trajectories, which become the current one.
- Finally, it unrolls the current trajectory (i.e., it advances it over time). The getOutput() member function returns the current trajectory, which includes the CoM, DCM, and footstep ones. The Generator requires the user to set the robot model using the setRobotModel() member function, before invoking the initialize() member function, which configures the Generator. As input, which is set by the setInput() member function, the Generator requires an instance of the UnicycleTrajectoryGeneratorInput struct.
Base classes
-
template<class _Input, class _Output>class BipedalLocomotion::System::Advanceable<UnicycleTrajectoryGeneratorInput, UnicycleTrajectoryGeneratorOutput>
- Basic class that represents a discrete system.
Constructors, destructors, conversion operators
Public functions
- auto setRobotContactFrames(const iDynTree::Model& model) -> bool
- Set the robot contact frames.
-
auto initialize(std::weak_ptr<const ParametersHandler::
IParametersHandler> handler) -> bool override -
auto initialize(std::weak_ptr<const ParametersHandler::
IParametersHandler> handler, const Eigen::Vector3d& initialBasePosition, const manif::SE3d& leftToRightTransform) -> bool - Initialize the planner.
-
auto initialize(std::weak_ptr<const ParametersHandler::
IParametersHandler> handler, const manif::SE3d& leftToRightTransform) -> bool - Initialize the planner.
-
auto initialize(std::weak_ptr<const ParametersHandler::
IParametersHandler> handler, const Eigen::Vector3d& initialBasePosition) -> bool - Initialize the planner.
- auto getOutput() const -> const UnicycleTrajectoryGeneratorOutput& override
- Get the output of the planner.
- auto isOutputValid() const -> bool override
- Check if the output is valid.
- auto setInput(const UnicycleTrajectoryGeneratorInput& input) -> bool override
- Set the input of the planner.
- auto advance() -> bool override
- Advance the planner.
- auto getSamplingTime() const -> std::chrono::nanoseconds
- Get the sampling time of the planner.
- void setFeetTransform(const manif::SE3d& leftFootTransform, const manif::SE3d& rightFootTransform)
- Set the feet transforms to use when regenerating the trajectory.
Function documentation
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: setRobotContactFrames(const iDynTree::Model& model)
Set the robot contact frames.
Parameters | |
---|---|
model | iDynTree::Model of the robot considered. |
It should be called after the initialize() function. It checks if the contact frames names parsed by the initialize() function exist. If yes, it sets the related contact frames indexes and returns true. Otherwise, it sets the Impl::FSM::State back to NotInitialized and returns false.
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: initialize(std::weak_ptr<const ParametersHandler:: IParametersHandler> handler) override
Initialize the planner. @note The following parameters are required by the class: | Name | Type | Default | Example | Description | | :-------------------------: | :------------: | :---------------: | :-------------: | :-----------------------------------------------------: | | `planner_advance_time_in_s` | double | 0.08 | - | The time in advance at which the planner is called | | `dt` | double | 0.002 | - | The sampling time of the trajectory generator | | `leftContactFrameName` | string | - | "l_sole" | Name of the left foot contact frame | | `rightContactFrameName` | string | - | "r_sole" | Name of the right foot contact frame | | `use_zmp_generator` | bool | false | - | If true enables the zmp generator | Implicitely, the class needs also all the parameters required by the Bipedalocotion::Planner::UnicyclePlanner class.
clang-format on
@param handler Pointer to the parameter handler. @return True in case of success, false otherwise.
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: initialize(std::weak_ptr<const ParametersHandler:: IParametersHandler> handler,
const Eigen::Vector3d& initialBasePosition,
const manif::SE3d& leftToRightTransform)
Initialize the planner.
Parameters | |
---|---|
handler | Pointer to the parameter handler. |
initialBasePosition | Initial position of the base. |
leftToRightTransform | Transformation Matrix between the left and right foot. |
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: initialize(std::weak_ptr<const ParametersHandler:: IParametersHandler> handler,
const manif::SE3d& leftToRightTransform)
Initialize the planner.
Parameters | |
---|---|
handler | Pointer to the parameter handler. |
leftToRightTransform | Transformation Matrix between the left and right foot. |
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: initialize(std::weak_ptr<const ParametersHandler:: IParametersHandler> handler,
const Eigen::Vector3d& initialBasePosition)
Initialize the planner.
Parameters | |
---|---|
handler | Pointer to the parameter handler. |
initialBasePosition | Initial position of the base. |
const UnicycleTrajectoryGeneratorOutput& BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: getOutput() const override
Get the output of the planner.
Returns | Output of the planner. |
---|
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: isOutputValid() const override
Check if the output is valid.
Returns | True if the output is valid, false otherwise. |
---|
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: setInput(const UnicycleTrajectoryGeneratorInput& input) override
Set the input of the planner.
Parameters | |
---|---|
input | Input of the planner. |
Returns | True in case of success, false otherwise. |
bool BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: advance() override
Advance the planner.
Returns | True in case of success, false otherwise. |
---|
std::chrono::nanoseconds BipedalLocomotion:: Planners:: UnicycleTrajectoryGenerator:: getSamplingTime() const
Get the sampling time of the planner.
Returns | Sampling time of the planner. |
---|