mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-31 18:47:21 +08:00
rover: add rover-specific position setpoint
This commit is contained in:
committed by
chfriedrich98
parent
9fe98b0724
commit
ca76d287d4
@@ -174,6 +174,7 @@ set(msg_files
|
|||||||
RcParameterMap.msg
|
RcParameterMap.msg
|
||||||
RoverAttitudeSetpoint.msg
|
RoverAttitudeSetpoint.msg
|
||||||
RoverAttitudeStatus.msg
|
RoverAttitudeStatus.msg
|
||||||
|
RoverPositionSetpoint.msg
|
||||||
RoverRateSetpoint.msg
|
RoverRateSetpoint.msg
|
||||||
RoverRateStatus.msg
|
RoverRateStatus.msg
|
||||||
RoverSteeringSetpoint.msg
|
RoverSteeringSetpoint.msg
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
uint64 timestamp # time since system start (microseconds)
|
||||||
|
|
||||||
|
float32[2] position_ned # 2-dimensional position setpoint in NED frame [m]
|
||||||
|
float32 cruising_speed # (Optional) Specify rover speed (Defaults to maximum speed)
|
||||||
|
|
||||||
|
float32 yaw # [rad] [-pi,pi] from North. Optional, NAN if not set. Mecanum only.
|
||||||
@@ -38,7 +38,13 @@ using namespace time_literals;
|
|||||||
AckermannPosControl::AckermannPosControl(ModuleParams *parent) : ModuleParams(parent)
|
AckermannPosControl::AckermannPosControl(ModuleParams *parent) : ModuleParams(parent)
|
||||||
{
|
{
|
||||||
_pure_pursuit_status_pub.advertise();
|
_pure_pursuit_status_pub.advertise();
|
||||||
|
_rover_position_setpoint_pub.advertise();
|
||||||
_ackermann_velocity_setpoint_pub.advertise();
|
_ackermann_velocity_setpoint_pub.advertise();
|
||||||
|
|
||||||
|
// Initially set to NaN to indicate that the rover has no position setpoint
|
||||||
|
_rover_position_setpoint.position_ned[0] = NAN;
|
||||||
|
_rover_position_setpoint.position_ned[1] = NAN;
|
||||||
|
|
||||||
updateParams();
|
updateParams();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -62,6 +68,10 @@ void AckermannPosControl::updatePosControl()
|
|||||||
updateSubscriptions();
|
updateSubscriptions();
|
||||||
|
|
||||||
if (_vehicle_control_mode.flag_control_position_enabled && _vehicle_control_mode.flag_armed && runSanityChecks()) {
|
if (_vehicle_control_mode.flag_control_position_enabled && _vehicle_control_mode.flag_armed && runSanityChecks()) {
|
||||||
|
if (_vehicle_control_mode.flag_control_offboard_enabled) {
|
||||||
|
generatePositionSetpoint();
|
||||||
|
}
|
||||||
|
|
||||||
generateVelocitySetpoint();
|
generateVelocitySetpoint();
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -96,6 +106,30 @@ void AckermannPosControl::updateSubscriptions()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AckermannPosControl::generatePositionSetpoint()
|
||||||
|
{
|
||||||
|
if (_offboard_control_mode_sub.updated()) {
|
||||||
|
_offboard_control_mode_sub.copy(&_offboard_control_mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!_offboard_control_mode.position) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
trajectory_setpoint_s trajectory_setpoint{};
|
||||||
|
_trajectory_setpoint_sub.copy(&trajectory_setpoint);
|
||||||
|
|
||||||
|
// Translate trajectory setpoint to rover position setpoint
|
||||||
|
rover_position_setpoint_s rover_position_setpoint{};
|
||||||
|
rover_position_setpoint.timestamp = _timestamp;
|
||||||
|
rover_position_setpoint.position_ned[0] = trajectory_setpoint.position[0];
|
||||||
|
rover_position_setpoint.position_ned[1] = trajectory_setpoint.position[1];
|
||||||
|
rover_position_setpoint.cruising_speed = _param_ro_speed_limit.get();
|
||||||
|
rover_position_setpoint.yaw = NAN;
|
||||||
|
_rover_position_setpoint_pub.publish(rover_position_setpoint);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void AckermannPosControl::generateVelocitySetpoint()
|
void AckermannPosControl::generateVelocitySetpoint()
|
||||||
{
|
{
|
||||||
// Manual Position Mode
|
// Manual Position Mode
|
||||||
@@ -110,9 +144,11 @@ void AckermannPosControl::generateVelocitySetpoint()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Offboard Position Mode
|
// Rover Position Setpoint
|
||||||
if (_offboard_control_mode_sub.copy(&_offboard_control_mode) && _offboard_control_mode.position) {
|
if (_rover_position_setpoint_sub.copy(&_rover_position_setpoint)
|
||||||
|
&& PX4_ISFINITE(_rover_position_setpoint.position_ned[0]) && PX4_ISFINITE(_rover_position_setpoint.position_ned[1])) {
|
||||||
goToPositionMode();
|
goToPositionMode();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -320,15 +356,16 @@ float AckermannPosControl::calcSpeedSetpoint(const float cruising_speed, const f
|
|||||||
|
|
||||||
void AckermannPosControl::goToPositionMode()
|
void AckermannPosControl::goToPositionMode()
|
||||||
{
|
{
|
||||||
trajectory_setpoint_s trajectory_setpoint{};
|
const Vector2f target_waypoint_ned(_rover_position_setpoint.position_ned[0], _rover_position_setpoint.position_ned[1]);
|
||||||
_trajectory_setpoint_sub.copy(&trajectory_setpoint);
|
|
||||||
const Vector2f target_waypoint_ned(trajectory_setpoint.position[0], trajectory_setpoint.position[1]);
|
|
||||||
const float distance_to_target = (target_waypoint_ned - _curr_pos_ned).norm();
|
const float distance_to_target = (target_waypoint_ned - _curr_pos_ned).norm();
|
||||||
|
|
||||||
if (distance_to_target > _param_nav_acc_rad.get()) {
|
if (distance_to_target > _param_nav_acc_rad.get()) {
|
||||||
const float speed_setpoint = math::trajectory::computeMaxSpeedFromDistance(_param_ro_jerk_limit.get(),
|
const float speed_setpoint = math::trajectory::computeMaxSpeedFromDistance(_param_ro_jerk_limit.get(),
|
||||||
_param_ro_decel_limit.get(), distance_to_target, 0.f);
|
_param_ro_decel_limit.get(), distance_to_target, 0.f);
|
||||||
const float speed_body_x_setpoint = math::min(speed_setpoint, _param_ro_speed_limit.get());
|
const float max_speed = PX4_ISFINITE(_rover_position_setpoint.cruising_speed) ?
|
||||||
|
_rover_position_setpoint.cruising_speed :
|
||||||
|
_param_ro_speed_limit.get();
|
||||||
|
const float speed_body_x_setpoint = math::min(speed_setpoint, max_speed);
|
||||||
pure_pursuit_status_s pure_pursuit_status{};
|
pure_pursuit_status_s pure_pursuit_status{};
|
||||||
pure_pursuit_status.timestamp = _timestamp;
|
pure_pursuit_status.timestamp = _timestamp;
|
||||||
const float yaw_setpoint = PurePursuit::calcTargetBearing(pure_pursuit_status, _param_pp_lookahd_gain.get(),
|
const float yaw_setpoint = PurePursuit::calcTargetBearing(pure_pursuit_status, _param_pp_lookahd_gain.get(),
|
||||||
|
|||||||
@@ -49,6 +49,7 @@
|
|||||||
// uORB includes
|
// uORB includes
|
||||||
#include <uORB/Publication.hpp>
|
#include <uORB/Publication.hpp>
|
||||||
#include <uORB/Subscription.hpp>
|
#include <uORB/Subscription.hpp>
|
||||||
|
#include <uORB/topics/rover_position_setpoint.h>
|
||||||
#include <uORB/topics/ackermann_velocity_setpoint.h>
|
#include <uORB/topics/ackermann_velocity_setpoint.h>
|
||||||
#include <uORB/topics/vehicle_control_mode.h>
|
#include <uORB/topics/vehicle_control_mode.h>
|
||||||
#include <uORB/topics/manual_control_setpoint.h>
|
#include <uORB/topics/manual_control_setpoint.h>
|
||||||
@@ -93,6 +94,11 @@ private:
|
|||||||
*/
|
*/
|
||||||
void updateSubscriptions();
|
void updateSubscriptions();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Generate and publish roverPositionSetpoint from position of trajectorySetpoint.
|
||||||
|
*/
|
||||||
|
void generatePositionSetpoint();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Generate and publish roverVelocitySetpoint from manualControlSetpoint (Position Mode) or
|
* @brief Generate and publish roverVelocitySetpoint from manualControlSetpoint (Position Mode) or
|
||||||
* positionSetpointTriplet (Auto Mode) or roverPositionSetpoint.
|
* positionSetpointTriplet (Auto Mode) or roverPositionSetpoint.
|
||||||
@@ -110,7 +116,7 @@ private:
|
|||||||
void autoPositionMode();
|
void autoPositionMode();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Generate and publish roverVelocitySetpoint from trajectorySetpoint.
|
* @brief Generate and publish roverVelocitySetpoint from roverPositionSetpoint.
|
||||||
*/
|
*/
|
||||||
void goToPositionMode();
|
void goToPositionMode();
|
||||||
|
|
||||||
@@ -169,13 +175,16 @@ private:
|
|||||||
uORB::Subscription _vehicle_attitude_sub{ORB_ID(vehicle_attitude)};
|
uORB::Subscription _vehicle_attitude_sub{ORB_ID(vehicle_attitude)};
|
||||||
uORB::Subscription _vehicle_local_position_sub{ORB_ID(vehicle_local_position)};
|
uORB::Subscription _vehicle_local_position_sub{ORB_ID(vehicle_local_position)};
|
||||||
uORB::Subscription _position_setpoint_triplet_sub{ORB_ID(position_setpoint_triplet)};
|
uORB::Subscription _position_setpoint_triplet_sub{ORB_ID(position_setpoint_triplet)};
|
||||||
|
uORB::Subscription _rover_position_setpoint_sub{ORB_ID(rover_position_setpoint)};
|
||||||
vehicle_control_mode_s _vehicle_control_mode{};
|
vehicle_control_mode_s _vehicle_control_mode{};
|
||||||
offboard_control_mode_s _offboard_control_mode{};
|
offboard_control_mode_s _offboard_control_mode{};
|
||||||
|
rover_position_setpoint_s _rover_position_setpoint{};
|
||||||
|
|
||||||
// uORB publications
|
// uORB publications
|
||||||
uORB::Publication<ackermann_velocity_setpoint_s> _ackermann_velocity_setpoint_pub{ORB_ID(ackermann_velocity_setpoint)};
|
uORB::Publication<ackermann_velocity_setpoint_s> _ackermann_velocity_setpoint_pub{ORB_ID(ackermann_velocity_setpoint)};
|
||||||
uORB::Publication<position_controller_status_s> _position_controller_status_pub{ORB_ID(position_controller_status)};
|
uORB::Publication<position_controller_status_s> _position_controller_status_pub{ORB_ID(position_controller_status)};
|
||||||
uORB::Publication<pure_pursuit_status_s> _pure_pursuit_status_pub{ORB_ID(pure_pursuit_status)};
|
uORB::Publication<pure_pursuit_status_s> _pure_pursuit_status_pub{ORB_ID(pure_pursuit_status)};
|
||||||
|
uORB::Publication<rover_position_setpoint_s> _rover_position_setpoint_pub{ORB_ID(rover_position_setpoint)};
|
||||||
|
|
||||||
// Variables
|
// Variables
|
||||||
hrt_abstime _timestamp{0};
|
hrt_abstime _timestamp{0};
|
||||||
|
|||||||
Reference in New Issue
Block a user