mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-06-02 20:28:37 +08:00
Revert "commander: publish full home attitude, not only yaw (#19717)"
Build all targets / Scan for Board Targets (push) Has been cancelled
Build all targets / Build Group [${{ matrix.group }}][${{ matrix.arch == 'nuttx' && 'x86' || 'arm64' }}] (push) Has been cancelled
Build all targets / Upload Artifacts to S3 (push) Has been cancelled
Build all targets / Create Release and Upload Artifacts (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_fmu-v5_default) (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_sitl_default) (push) Has been cancelled
Checks / build (check_format) (push) Has been cancelled
Checks / build (check_newlines) (push) Has been cancelled
Checks / build (module_documentation) (push) Has been cancelled
Checks / build (px4_fmu-v2_default stack_check) (push) Has been cancelled
Checks / build (px4_sitl_allyes) (push) Has been cancelled
Checks / build (shellcheck_all) (push) Has been cancelled
Checks / build (tests) (push) Has been cancelled
Checks / build (tests_coverage) (push) Has been cancelled
Checks / build (validate_module_configs) (push) Has been cancelled
Clang Tidy / build (push) Has been cancelled
MacOS build / build (px4_fmu-v5_default) (push) Has been cancelled
MacOS build / build (px4_sitl) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:22.04) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:24.04) (push) Has been cancelled
Container build / Set Tags and Variables (push) Has been cancelled
Container build / Build Container (amd64) (push) Has been cancelled
Container build / Build Container (arm64) (push) Has been cancelled
Container build / Deploy To Registry (push) Has been cancelled
EKF Update Change Indicator / unit_tests (push) Has been cancelled
Failsafe Simulator Build / build (failsafe_web) (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v5x (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v6x (push) Has been cancelled
FLASH usage analysis / Publish Results (push) Has been cancelled
ITCM check / Checking nxp_tropic-community (push) Has been cancelled
ITCM check / Checking px4_fmu-v5x (push) Has been cancelled
ITCM check / Checking px4_fmu-v6xrt (push) Has been cancelled
MAVROS Mission Tests / build (map[mission:MC_mission_box vehicle:iris]) (push) Has been cancelled
MAVROS Offboard Tests / build (map[test_file:mavros_posix_tests_offboard_posctl.test vehicle:iris]) (push) Has been cancelled
Nuttx Target with extra env config / build (px4_fmu-v5_default) (push) Has been cancelled
Python CI Checks / build (push) Has been cancelled
ROS Integration Tests / build (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:humble ubuntu:jammy]) (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:jazzy ubuntu:noble]) (push) Has been cancelled
SITL Tests / Testing PX4 tailsitter (push) Has been cancelled
SITL Tests / Testing PX4 iris (push) Has been cancelled
SITL Tests / Testing PX4 standard_vtol (push) Has been cancelled
Docs - Crowdin - Upload Guide sources (en) / upload-to-crowdin (push) Has been cancelled
Docs - Deploy PX4 User Guide / build (push) Has been cancelled
Docs - Deploy PX4 User Guide / deploy (push) Has been cancelled
Build all targets / Scan for Board Targets (push) Has been cancelled
Build all targets / Build Group [${{ matrix.group }}][${{ matrix.arch == 'nuttx' && 'x86' || 'arm64' }}] (push) Has been cancelled
Build all targets / Upload Artifacts to S3 (push) Has been cancelled
Build all targets / Create Release and Upload Artifacts (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_fmu-v5_default) (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_sitl_default) (push) Has been cancelled
Checks / build (check_format) (push) Has been cancelled
Checks / build (check_newlines) (push) Has been cancelled
Checks / build (module_documentation) (push) Has been cancelled
Checks / build (px4_fmu-v2_default stack_check) (push) Has been cancelled
Checks / build (px4_sitl_allyes) (push) Has been cancelled
Checks / build (shellcheck_all) (push) Has been cancelled
Checks / build (tests) (push) Has been cancelled
Checks / build (tests_coverage) (push) Has been cancelled
Checks / build (validate_module_configs) (push) Has been cancelled
Clang Tidy / build (push) Has been cancelled
MacOS build / build (px4_fmu-v5_default) (push) Has been cancelled
MacOS build / build (px4_sitl) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:22.04) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:24.04) (push) Has been cancelled
Container build / Set Tags and Variables (push) Has been cancelled
Container build / Build Container (amd64) (push) Has been cancelled
Container build / Build Container (arm64) (push) Has been cancelled
Container build / Deploy To Registry (push) Has been cancelled
EKF Update Change Indicator / unit_tests (push) Has been cancelled
Failsafe Simulator Build / build (failsafe_web) (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v5x (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v6x (push) Has been cancelled
FLASH usage analysis / Publish Results (push) Has been cancelled
ITCM check / Checking nxp_tropic-community (push) Has been cancelled
ITCM check / Checking px4_fmu-v5x (push) Has been cancelled
ITCM check / Checking px4_fmu-v6xrt (push) Has been cancelled
MAVROS Mission Tests / build (map[mission:MC_mission_box vehicle:iris]) (push) Has been cancelled
MAVROS Offboard Tests / build (map[test_file:mavros_posix_tests_offboard_posctl.test vehicle:iris]) (push) Has been cancelled
Nuttx Target with extra env config / build (px4_fmu-v5_default) (push) Has been cancelled
Python CI Checks / build (push) Has been cancelled
ROS Integration Tests / build (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:humble ubuntu:jammy]) (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:jazzy ubuntu:noble]) (push) Has been cancelled
SITL Tests / Testing PX4 tailsitter (push) Has been cancelled
SITL Tests / Testing PX4 iris (push) Has been cancelled
SITL Tests / Testing PX4 standard_vtol (push) Has been cancelled
Docs - Crowdin - Upload Guide sources (en) / upload-to-crowdin (push) Has been cancelled
Docs - Deploy PX4 User Guide / build (push) Has been cancelled
Docs - Deploy PX4 User Guide / deploy (push) Has been cancelled
This reverts commit 6855aa57c4.
This commit is contained in:
@@ -12,8 +12,6 @@ float32 x # X coordinate in meters
|
|||||||
float32 y # Y coordinate in meters
|
float32 y # Y coordinate in meters
|
||||||
float32 z # Z coordinate in meters
|
float32 z # Z coordinate in meters
|
||||||
|
|
||||||
float32 roll # Pitch angle in radians
|
|
||||||
float32 pitch # Roll angle in radians
|
|
||||||
float32 yaw # Yaw angle in radians
|
float32 yaw # Yaw angle in radians
|
||||||
|
|
||||||
bool valid_alt # true when the altitude has been set
|
bool valid_alt # true when the altitude has been set
|
||||||
|
|||||||
@@ -999,10 +999,6 @@ Commander::handle_command(const vehicle_command_s &cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
float roll = matrix::wrap_2pi(math::radians(cmd.param2));
|
|
||||||
roll = PX4_ISFINITE(roll) ? roll : 0.0f;
|
|
||||||
float pitch = matrix::wrap_2pi(math::radians(cmd.param3));
|
|
||||||
pitch = PX4_ISFINITE(pitch) ? pitch : 0.0f;
|
|
||||||
float yaw = matrix::wrap_2pi(math::radians(cmd.param4));
|
float yaw = matrix::wrap_2pi(math::radians(cmd.param4));
|
||||||
yaw = PX4_ISFINITE(yaw) ? yaw : (float)NAN;
|
yaw = PX4_ISFINITE(yaw) ? yaw : (float)NAN;
|
||||||
const double lat = cmd.param5;
|
const double lat = cmd.param5;
|
||||||
@@ -1011,7 +1007,7 @@ Commander::handle_command(const vehicle_command_s &cmd)
|
|||||||
|
|
||||||
if (PX4_ISFINITE(lat) && PX4_ISFINITE(lon) && PX4_ISFINITE(alt)) {
|
if (PX4_ISFINITE(lat) && PX4_ISFINITE(lon) && PX4_ISFINITE(alt)) {
|
||||||
|
|
||||||
if (_home_position.setManually(lat, lon, alt, roll, pitch, yaw)) {
|
if (_home_position.setManually(lat, lon, alt, yaw)) {
|
||||||
|
|
||||||
cmd_result = vehicle_command_ack_s::VEHICLE_CMD_RESULT_ACCEPTED;
|
cmd_result = vehicle_command_ack_s::VEHICLE_CMD_RESULT_ACCEPTED;
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2022-2025 PX4 Development Team. All rights reserved.
|
* Copyright (c) 2022-2023 PX4 Development Team. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@@ -99,9 +99,7 @@ bool HomePosition::setHomePosition(bool force)
|
|||||||
const vehicle_local_position_s &lpos = _local_position_sub.get();
|
const vehicle_local_position_s &lpos = _local_position_sub.get();
|
||||||
_heading_reset_counter = lpos.heading_reset_counter; // TODO: should not be here
|
_heading_reset_counter = lpos.heading_reset_counter; // TODO: should not be here
|
||||||
|
|
||||||
const vehicle_attitude_s &attitude = _attitude_sub.get();
|
fillLocalHomePos(home, lpos);
|
||||||
|
|
||||||
fillLocalHomePos(home, lpos, attitude);
|
|
||||||
updated = true;
|
updated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,25 +135,19 @@ bool HomePosition::setHomePosition(bool force)
|
|||||||
return updated;
|
return updated;
|
||||||
}
|
}
|
||||||
|
|
||||||
void HomePosition::fillLocalHomePos(home_position_s &home, const vehicle_local_position_s &lpos,
|
void HomePosition::fillLocalHomePos(home_position_s &home, const vehicle_local_position_s &lpos)
|
||||||
const vehicle_attitude_s &attitude)
|
|
||||||
{
|
{
|
||||||
matrix::Quatf q(attitude.q);
|
fillLocalHomePos(home, lpos.x, lpos.y, lpos.z, lpos.heading);
|
||||||
matrix::Eulerf euler(q);
|
|
||||||
fillLocalHomePos(home, lpos.x, lpos.y, lpos.z, euler(0), euler(1), euler(2));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HomePosition::fillLocalHomePos(home_position_s &home, float x, float y, float z, float roll, float pitch,
|
void HomePosition::fillLocalHomePos(home_position_s &home, float x, float y, float z, float heading)
|
||||||
float yaw)
|
|
||||||
{
|
{
|
||||||
home.x = x;
|
home.x = x;
|
||||||
home.y = y;
|
home.y = y;
|
||||||
home.z = z;
|
home.z = z;
|
||||||
home.valid_lpos = true;
|
home.valid_lpos = true;
|
||||||
|
|
||||||
home.roll = roll;
|
home.yaw = heading;
|
||||||
home.pitch = pitch;
|
|
||||||
home.yaw = yaw;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HomePosition::fillGlobalHomePos(home_position_s &home, const vehicle_global_position_s &gpos)
|
void HomePosition::fillGlobalHomePos(home_position_s &home, const vehicle_global_position_s &gpos)
|
||||||
@@ -237,7 +229,7 @@ void HomePosition::setInAirHomePosition()
|
|||||||
ref_pos.project(home.lat, home.lon, home_x, home_y);
|
ref_pos.project(home.lat, home.lon, home_x, home_y);
|
||||||
|
|
||||||
const float home_z = -(home.alt - lpos.ref_alt);
|
const float home_z = -(home.alt - lpos.ref_alt);
|
||||||
fillLocalHomePos(home, home_x, home_y, home_z, NAN, NAN, NAN);
|
fillLocalHomePos(home, home_x, home_y, home_z, NAN);
|
||||||
|
|
||||||
home.timestamp = hrt_absolute_time();
|
home.timestamp = hrt_absolute_time();
|
||||||
home.update_count++;
|
home.update_count++;
|
||||||
@@ -253,7 +245,7 @@ void HomePosition::setInAirHomePosition()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool HomePosition::setManually(double lat, double lon, float alt, float roll, float pitch, float yaw)
|
bool HomePosition::setManually(double lat, double lon, float alt, float yaw)
|
||||||
{
|
{
|
||||||
const vehicle_local_position_s &vehicle_local_position = _local_position_sub.get();
|
const vehicle_local_position_s &vehicle_local_position = _local_position_sub.get();
|
||||||
|
|
||||||
@@ -276,8 +268,6 @@ bool HomePosition::setManually(double lat, double lon, float alt, float roll, fl
|
|||||||
home.z = -(alt - vehicle_local_position.ref_alt);
|
home.z = -(alt - vehicle_local_position.ref_alt);
|
||||||
home.valid_lpos = vehicle_local_position.xy_valid && vehicle_local_position.z_valid;
|
home.valid_lpos = vehicle_local_position.xy_valid && vehicle_local_position.z_valid;
|
||||||
|
|
||||||
home.roll = roll;
|
|
||||||
home.pitch = pitch;
|
|
||||||
home.yaw = yaw;
|
home.yaw = yaw;
|
||||||
|
|
||||||
home.timestamp = hrt_absolute_time();
|
home.timestamp = hrt_absolute_time();
|
||||||
@@ -313,7 +303,6 @@ void HomePosition::update(bool set_automatically, bool check_if_changed)
|
|||||||
{
|
{
|
||||||
_local_position_sub.update();
|
_local_position_sub.update();
|
||||||
_global_position_sub.update();
|
_global_position_sub.update();
|
||||||
_attitude_sub.update();
|
|
||||||
|
|
||||||
if (_vehicle_air_data_sub.updated()) {
|
if (_vehicle_air_data_sub.updated()) {
|
||||||
vehicle_air_data_s baro_data;
|
vehicle_air_data_s baro_data;
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
*
|
*
|
||||||
* Copyright (c) 2022-2025 PX4 Development Team. All rights reserved.
|
* Copyright (c) 2022-2023 PX4 Development Team. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@@ -39,7 +39,6 @@
|
|||||||
#include <uORB/topics/sensor_gps.h>
|
#include <uORB/topics/sensor_gps.h>
|
||||||
#include <uORB/topics/vehicle_global_position.h>
|
#include <uORB/topics/vehicle_global_position.h>
|
||||||
#include <uORB/topics/vehicle_local_position.h>
|
#include <uORB/topics/vehicle_local_position.h>
|
||||||
#include <uORB/topics/vehicle_attitude.h>
|
|
||||||
#include <uORB/topics/failsafe_flags.h>
|
#include <uORB/topics/failsafe_flags.h>
|
||||||
#include <uORB/topics/vehicle_air_data.h>
|
#include <uORB/topics/vehicle_air_data.h>
|
||||||
#include <lib/mathlib/math/filter/AlphaFilter.hpp>
|
#include <lib/mathlib/math/filter/AlphaFilter.hpp>
|
||||||
@@ -65,7 +64,7 @@ public:
|
|||||||
|
|
||||||
bool setHomePosition(bool force = false);
|
bool setHomePosition(bool force = false);
|
||||||
void setInAirHomePosition();
|
void setInAirHomePosition();
|
||||||
bool setManually(double lat, double lon, float alt, float roll, float pitch, float yaw);
|
bool setManually(double lat, double lon, float alt, float yaw);
|
||||||
void setTakeoffTime(uint64_t takeoff_time) { _takeoff_time = takeoff_time; }
|
void setTakeoffTime(uint64_t takeoff_time) { _takeoff_time = takeoff_time; }
|
||||||
|
|
||||||
void update(bool set_automatically, bool check_if_changed);
|
void update(bool set_automatically, bool check_if_changed);
|
||||||
@@ -77,9 +76,8 @@ private:
|
|||||||
void setHomePosValid();
|
void setHomePosValid();
|
||||||
void updateHomePositionYaw(float yaw);
|
void updateHomePositionYaw(float yaw);
|
||||||
|
|
||||||
static void fillLocalHomePos(home_position_s &home, const vehicle_local_position_s &lpos,
|
static void fillLocalHomePos(home_position_s &home, const vehicle_local_position_s &lpos);
|
||||||
const vehicle_attitude_s &attitude);
|
static void fillLocalHomePos(home_position_s &home, float x, float y, float z, float heading);
|
||||||
static void fillLocalHomePos(home_position_s &home, float x, float y, float z, float roll, float pitch, float yaw);
|
|
||||||
static void fillGlobalHomePos(home_position_s &home, const vehicle_global_position_s &gpos);
|
static void fillGlobalHomePos(home_position_s &home, const vehicle_global_position_s &gpos);
|
||||||
static void fillGlobalHomePos(home_position_s &home, double lat, double lon, double alt);
|
static void fillGlobalHomePos(home_position_s &home, double lat, double lon, double alt);
|
||||||
|
|
||||||
@@ -87,7 +85,6 @@ private:
|
|||||||
|
|
||||||
uORB::SubscriptionData<vehicle_global_position_s> _global_position_sub{ORB_ID(vehicle_global_position)};
|
uORB::SubscriptionData<vehicle_global_position_s> _global_position_sub{ORB_ID(vehicle_global_position)};
|
||||||
uORB::SubscriptionData<vehicle_local_position_s> _local_position_sub{ORB_ID(vehicle_local_position)};
|
uORB::SubscriptionData<vehicle_local_position_s> _local_position_sub{ORB_ID(vehicle_local_position)};
|
||||||
uORB::SubscriptionData<vehicle_attitude_s> _attitude_sub{ORB_ID(vehicle_attitude)};
|
|
||||||
uORB::Subscription _vehicle_air_data_sub{ORB_ID(vehicle_air_data)};
|
uORB::Subscription _vehicle_air_data_sub{ORB_ID(vehicle_air_data)};
|
||||||
|
|
||||||
uint64_t _last_gps_timestamp{0};
|
uint64_t _last_gps_timestamp{0};
|
||||||
|
|||||||
@@ -75,7 +75,7 @@ private:
|
|||||||
msg.y = home.y;
|
msg.y = home.y;
|
||||||
msg.z = home.z;
|
msg.z = home.z;
|
||||||
|
|
||||||
matrix::Quatf q(matrix::Eulerf(home.roll, home.pitch, home.yaw));
|
matrix::Quatf q(matrix::Eulerf(0.f, 0.f, home.yaw));
|
||||||
q.copyTo(msg.q);
|
q.copyTo(msg.q);
|
||||||
|
|
||||||
msg.approach_x = 0.f;
|
msg.approach_x = 0.f;
|
||||||
|
|||||||
Reference in New Issue
Block a user