2024-09-30 11:59:35 +08:00
|
|
|
//
|
|
|
|
// Created by tlab-uav on 24-9-30.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "ocs2_quadruped_controller/control/TargetManager.h"
|
|
|
|
|
|
|
|
#include <ocs2_core/misc/LoadData.h>
|
|
|
|
#include <ocs2_robotic_tools/common/RotationTransforms.h>
|
|
|
|
|
|
|
|
#include "ocs2_quadruped_controller/control/CtrlComponent.h"
|
|
|
|
|
|
|
|
namespace ocs2::legged_robot {
|
|
|
|
TargetManager::TargetManager(CtrlComponent &ctrl_component,
|
|
|
|
const std::shared_ptr<ReferenceManagerInterface> &referenceManagerPtr,
|
|
|
|
const std::string &task_file,
|
|
|
|
const std::string &reference_file)
|
|
|
|
: ctrl_component_(ctrl_component),
|
|
|
|
referenceManagerPtr_(referenceManagerPtr) {
|
|
|
|
default_joint_state_ = vector_t::Zero(12);
|
|
|
|
loadData::loadCppDataType(reference_file, "comHeight", command_height_);
|
|
|
|
loadData::loadEigenMatrix(reference_file, "defaultJointState", default_joint_state_);
|
|
|
|
loadData::loadCppDataType(task_file, "mpc.timeHorizon", time_to_target_);
|
2024-09-30 15:10:08 +08:00
|
|
|
loadData::loadCppDataType(reference_file, "targetRotationVelocity", target_rotation_velocity_);
|
|
|
|
loadData::loadCppDataType(reference_file, "targetDisplacementVelocity", target_displacement_velocity_);
|
2024-09-30 11:59:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void TargetManager::update() {
|
|
|
|
vector_t cmdGoal = vector_t::Zero(6);
|
2024-09-30 15:10:08 +08:00
|
|
|
cmdGoal[0] = ctrl_component_.control_inputs_.ly * target_displacement_velocity_;
|
|
|
|
cmdGoal[1] = -ctrl_component_.control_inputs_.lx * target_displacement_velocity_;
|
2024-09-30 11:59:35 +08:00
|
|
|
cmdGoal[2] = ctrl_component_.control_inputs_.ry;
|
2024-09-30 15:10:08 +08:00
|
|
|
cmdGoal[3] = -ctrl_component_.control_inputs_.rx * target_rotation_velocity_;
|
2024-09-30 11:59:35 +08:00
|
|
|
|
|
|
|
const vector_t currentPose = ctrl_component_.observation_.state.segment<6>(6);
|
|
|
|
const Eigen::Matrix<scalar_t, 3, 1> zyx = currentPose.tail(3);
|
|
|
|
vector_t cmdVelRot = getRotationMatrixFromZyxEulerAngles(zyx) * cmdGoal.head(3);
|
|
|
|
|
|
|
|
const scalar_t timeToTarget = time_to_target_;
|
|
|
|
const vector_t targetPose = [&]() {
|
|
|
|
vector_t target(6);
|
|
|
|
target(0) = currentPose(0) + cmdVelRot(0) * timeToTarget;
|
|
|
|
target(1) = currentPose(1) + cmdVelRot(1) * timeToTarget;
|
|
|
|
target(2) = command_height_;
|
|
|
|
target(3) = currentPose(3) + cmdGoal(3) * timeToTarget;
|
|
|
|
target(4) = 0;
|
|
|
|
target(5) = 0;
|
|
|
|
return target;
|
|
|
|
}();
|
|
|
|
|
|
|
|
const scalar_t targetReachingTime = ctrl_component_.observation_.time + timeToTarget;
|
|
|
|
auto trajectories =
|
|
|
|
targetPoseToTargetTrajectories(targetPose, ctrl_component_.observation_, targetReachingTime);
|
|
|
|
trajectories.stateTrajectory[0].head(3) = cmdVelRot;
|
|
|
|
trajectories.stateTrajectory[1].head(3) = cmdVelRot;
|
|
|
|
|
|
|
|
referenceManagerPtr_->setTargetTrajectories(std::move(trajectories));
|
|
|
|
}
|
|
|
|
}
|