mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-20 07:38:28 -04:00
SITL: SIM_VICON output MAVLink vision_position_delta
This commit is contained in:
parent
0a08793b7d
commit
dceb76c9f1
@ -204,6 +204,48 @@ void Vicon::update_vicon_position_estimate(const Location &loc,
|
|||||||
NULL, 0);
|
NULL, 0);
|
||||||
msg_buf[msg_buf_index].time_send_us = time_send_us;
|
msg_buf[msg_buf_index].time_send_us = time_send_us;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// determine time, position, and angular deltas
|
||||||
|
uint64_t time_delta = now_us - last_observation_usec;
|
||||||
|
|
||||||
|
Quaternion attitude_curr; // Rotation to current MAV_FRAME_BODY_FRD from MAV_FRAME_LOCAL_NED
|
||||||
|
attitude_curr.from_euler(roll, pitch, yaw); // Rotation to MAV_FRAME_LOCAL_NED from current MAV_FRAME_BODY_FRD
|
||||||
|
attitude_curr.invert();
|
||||||
|
|
||||||
|
Quaternion attitude_curr_prev = attitude_curr * _attitude_prev.inverse(); // Get rotation to current MAV_FRAME_BODY_FRD from previous MAV_FRAME_BODY_FRD
|
||||||
|
float angle_delta[3] = {attitude_curr_prev.get_euler_roll(),
|
||||||
|
attitude_curr_prev.get_euler_pitch(),
|
||||||
|
attitude_curr_prev.get_euler_yaw()};
|
||||||
|
|
||||||
|
Matrix3f body_ned_m;
|
||||||
|
attitude_curr.rotation_matrix(body_ned_m);
|
||||||
|
|
||||||
|
Vector3f pos_delta = body_ned_m * (pos_corrected - _position_prev);
|
||||||
|
float postion_delta[3] = {pos_delta.x, pos_delta.y, pos_delta.z};
|
||||||
|
|
||||||
|
// send vision position delta
|
||||||
|
// time_usec: (usec) Current time stamp
|
||||||
|
// time_delta_usec: (usec) Time since last reported camera frame
|
||||||
|
// angle_delta [3]: (radians) Roll, pitch, yaw angles that define rotation to current MAV_FRAME_BODY_FRD from previous MAV_FRAME_BODY_FRD
|
||||||
|
// delta_position [3]: (meters) Change in position: To current position from previous position rotated to current MAV_FRAME_BODY_FRD from MAV_FRAME_LOCAL_NED
|
||||||
|
// confidence: Normalized confidence level [0, 100]
|
||||||
|
if (should_send(ViconTypeMask::VISION_POSITION_DELTA) && get_free_msg_buf_index(msg_buf_index)) {
|
||||||
|
mavlink_msg_vision_position_delta_pack_chan(
|
||||||
|
system_id,
|
||||||
|
component_id,
|
||||||
|
mavlink_ch,
|
||||||
|
&msg_buf[msg_buf_index].obs_msg,
|
||||||
|
now_us + time_offset_us,
|
||||||
|
time_delta,
|
||||||
|
angle_delta,
|
||||||
|
postion_delta,
|
||||||
|
0.0f);
|
||||||
|
msg_buf[msg_buf_index].time_send_us = time_send_us;
|
||||||
|
}
|
||||||
|
|
||||||
|
// set previous position & attitude
|
||||||
|
_position_prev = pos_corrected;
|
||||||
|
_attitude_prev = attitude_curr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -218,4 +260,3 @@ void Vicon::update(const Location &loc, const Vector3f &position, const Vector3f
|
|||||||
maybe_send_heartbeat();
|
maybe_send_heartbeat();
|
||||||
update_vicon_position_estimate(loc, position, velocity, attitude);
|
update_vicon_position_estimate(loc, position, velocity, attitude);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +59,8 @@ private:
|
|||||||
enum class ViconTypeMask : uint8_t {
|
enum class ViconTypeMask : uint8_t {
|
||||||
VISION_POSITION_ESTIMATE = (1 << 0),
|
VISION_POSITION_ESTIMATE = (1 << 0),
|
||||||
VISION_SPEED_ESTIMATE = (1 << 1),
|
VISION_SPEED_ESTIMATE = (1 << 1),
|
||||||
VICON_POSITION_ESTIMATE = (1 << 2)
|
VICON_POSITION_ESTIMATE = (1 << 2),
|
||||||
|
VISION_POSITION_DELTA = (1 << 3)
|
||||||
};
|
};
|
||||||
|
|
||||||
// return true if the given message type should be sent
|
// return true if the given message type should be sent
|
||||||
@ -75,6 +76,10 @@ private:
|
|||||||
|
|
||||||
void maybe_send_heartbeat();
|
void maybe_send_heartbeat();
|
||||||
uint32_t last_heartbeat_ms;
|
uint32_t last_heartbeat_ms;
|
||||||
|
|
||||||
|
// position delta message
|
||||||
|
Quaternion _attitude_prev; // Rotation to previous MAV_FRAME_BODY_FRD from MAV_FRAME_LOCAL_NED
|
||||||
|
Vector3f _position_prev; // previous position from origin (m) MAV_FRAME_LOCAL_NED
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user