mavlink_msg_ahrs.h 8.73 KB
Newer Older
1
// MESSAGE AHRS PACKING
pixhawk's avatar
pixhawk committed
2

3
#define MAVLINK_MSG_ID_AHRS 163
pixhawk's avatar
pixhawk committed
4

5
typedef struct __mavlink_ahrs_t
pixhawk's avatar
pixhawk committed
6 7 8 9 10 11 12 13
{
 float omegaIx; ///< X gyro drift estimate rad/s
 float omegaIy; ///< Y gyro drift estimate rad/s
 float omegaIz; ///< Z gyro drift estimate rad/s
 float accel_weight; ///< average accel_weight
 float renorm_val; ///< average renormalisation value
 float error_rp; ///< average error_roll_pitch value
 float error_yaw; ///< average error_yaw value
14
} mavlink_ahrs_t;
pixhawk's avatar
pixhawk committed
15

16
#define MAVLINK_MSG_ID_AHRS_LEN 28
pixhawk's avatar
pixhawk committed
17 18 19 20
#define MAVLINK_MSG_ID_163_LEN 28



21 22
#define MAVLINK_MESSAGE_INFO_AHRS { \
	"AHRS", \
pixhawk's avatar
pixhawk committed
23
	7, \
24 25 26 27 28 29 30
	{  { "omegaIx", NULL, MAVLINK_TYPE_FLOAT, 0, 0, offsetof(mavlink_ahrs_t, omegaIx) }, \
         { "omegaIy", NULL, MAVLINK_TYPE_FLOAT, 0, 4, offsetof(mavlink_ahrs_t, omegaIy) }, \
         { "omegaIz", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_ahrs_t, omegaIz) }, \
         { "accel_weight", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_ahrs_t, accel_weight) }, \
         { "renorm_val", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_ahrs_t, renorm_val) }, \
         { "error_rp", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_ahrs_t, error_rp) }, \
         { "error_yaw", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_ahrs_t, error_yaw) }, \
pixhawk's avatar
pixhawk committed
31 32 33 34 35
         } \
}


/**
36
 * @brief Pack a ahrs message
pixhawk's avatar
pixhawk committed
37 38 39 40 41 42 43 44 45 46 47 48 49
 * @param system_id ID of this system
 * @param component_id ID of this component (e.g. 200 for IMU)
 * @param msg The MAVLink message to compress the data into
 *
 * @param omegaIx X gyro drift estimate rad/s
 * @param omegaIy Y gyro drift estimate rad/s
 * @param omegaIz Z gyro drift estimate rad/s
 * @param accel_weight average accel_weight
 * @param renorm_val average renormalisation value
 * @param error_rp average error_roll_pitch value
 * @param error_yaw average error_yaw value
 * @return length of the message in bytes (excluding serial stream start sign)
 */
50
static inline uint16_t mavlink_msg_ahrs_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
pixhawk's avatar
pixhawk committed
51 52 53 54 55 56 57 58 59 60 61 62
						       float omegaIx, float omegaIy, float omegaIz, float accel_weight, float renorm_val, float error_rp, float error_yaw)
{
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
	char buf[28];
	_mav_put_float(buf, 0, omegaIx);
	_mav_put_float(buf, 4, omegaIy);
	_mav_put_float(buf, 8, omegaIz);
	_mav_put_float(buf, 12, accel_weight);
	_mav_put_float(buf, 16, renorm_val);
	_mav_put_float(buf, 20, error_rp);
	_mav_put_float(buf, 24, error_yaw);

63
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, 28);
pixhawk's avatar
pixhawk committed
64
#else
65
	mavlink_ahrs_t packet;
pixhawk's avatar
pixhawk committed
66 67 68 69 70 71 72 73
	packet.omegaIx = omegaIx;
	packet.omegaIy = omegaIy;
	packet.omegaIz = omegaIz;
	packet.accel_weight = accel_weight;
	packet.renorm_val = renorm_val;
	packet.error_rp = error_rp;
	packet.error_yaw = error_yaw;

74
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, 28);
pixhawk's avatar
pixhawk committed
75 76
#endif

77 78
	msg->msgid = MAVLINK_MSG_ID_AHRS;
	return mavlink_finalize_message(msg, system_id, component_id, 28, 127);
pixhawk's avatar
pixhawk committed
79 80 81
}

/**
82
 * @brief Pack a ahrs message on a channel
pixhawk's avatar
pixhawk committed
83 84 85 86 87 88 89 90 91 92 93 94 95
 * @param system_id ID of this system
 * @param component_id ID of this component (e.g. 200 for IMU)
 * @param chan The MAVLink channel this message was sent over
 * @param msg The MAVLink message to compress the data into
 * @param omegaIx X gyro drift estimate rad/s
 * @param omegaIy Y gyro drift estimate rad/s
 * @param omegaIz Z gyro drift estimate rad/s
 * @param accel_weight average accel_weight
 * @param renorm_val average renormalisation value
 * @param error_rp average error_roll_pitch value
 * @param error_yaw average error_yaw value
 * @return length of the message in bytes (excluding serial stream start sign)
 */
96
static inline uint16_t mavlink_msg_ahrs_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
pixhawk's avatar
pixhawk committed
97 98 99 100 101 102 103 104 105 106 107 108 109
							   mavlink_message_t* msg,
						           float omegaIx,float omegaIy,float omegaIz,float accel_weight,float renorm_val,float error_rp,float error_yaw)
{
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
	char buf[28];
	_mav_put_float(buf, 0, omegaIx);
	_mav_put_float(buf, 4, omegaIy);
	_mav_put_float(buf, 8, omegaIz);
	_mav_put_float(buf, 12, accel_weight);
	_mav_put_float(buf, 16, renorm_val);
	_mav_put_float(buf, 20, error_rp);
	_mav_put_float(buf, 24, error_yaw);

110
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, 28);
pixhawk's avatar
pixhawk committed
111
#else
112
	mavlink_ahrs_t packet;
pixhawk's avatar
pixhawk committed
113 114 115 116 117 118 119 120
	packet.omegaIx = omegaIx;
	packet.omegaIy = omegaIy;
	packet.omegaIz = omegaIz;
	packet.accel_weight = accel_weight;
	packet.renorm_val = renorm_val;
	packet.error_rp = error_rp;
	packet.error_yaw = error_yaw;

121
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, 28);
pixhawk's avatar
pixhawk committed
122 123
#endif

124 125
	msg->msgid = MAVLINK_MSG_ID_AHRS;
	return mavlink_finalize_message_chan(msg, system_id, component_id, chan, 28, 127);
pixhawk's avatar
pixhawk committed
126 127 128
}

/**
129
 * @brief Encode a ahrs struct into a message
pixhawk's avatar
pixhawk committed
130 131 132 133
 *
 * @param system_id ID of this system
 * @param component_id ID of this component (e.g. 200 for IMU)
 * @param msg The MAVLink message to compress the data into
134
 * @param ahrs C-struct to read the message contents from
pixhawk's avatar
pixhawk committed
135
 */
136
static inline uint16_t mavlink_msg_ahrs_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_ahrs_t* ahrs)
pixhawk's avatar
pixhawk committed
137
{
138
	return mavlink_msg_ahrs_pack(system_id, component_id, msg, ahrs->omegaIx, ahrs->omegaIy, ahrs->omegaIz, ahrs->accel_weight, ahrs->renorm_val, ahrs->error_rp, ahrs->error_yaw);
pixhawk's avatar
pixhawk committed
139 140 141
}

/**
142
 * @brief Send a ahrs message
pixhawk's avatar
pixhawk committed
143 144 145 146 147 148 149 150 151 152 153 154
 * @param chan MAVLink channel to send the message
 *
 * @param omegaIx X gyro drift estimate rad/s
 * @param omegaIy Y gyro drift estimate rad/s
 * @param omegaIz Z gyro drift estimate rad/s
 * @param accel_weight average accel_weight
 * @param renorm_val average renormalisation value
 * @param error_rp average error_roll_pitch value
 * @param error_yaw average error_yaw value
 */
#ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS

155
static inline void mavlink_msg_ahrs_send(mavlink_channel_t chan, float omegaIx, float omegaIy, float omegaIz, float accel_weight, float renorm_val, float error_rp, float error_yaw)
pixhawk's avatar
pixhawk committed
156 157 158 159 160 161 162 163 164 165 166
{
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
	char buf[28];
	_mav_put_float(buf, 0, omegaIx);
	_mav_put_float(buf, 4, omegaIy);
	_mav_put_float(buf, 8, omegaIz);
	_mav_put_float(buf, 12, accel_weight);
	_mav_put_float(buf, 16, renorm_val);
	_mav_put_float(buf, 20, error_rp);
	_mav_put_float(buf, 24, error_yaw);

167
	_mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AHRS, buf, 28, 127);
pixhawk's avatar
pixhawk committed
168
#else
169
	mavlink_ahrs_t packet;
pixhawk's avatar
pixhawk committed
170 171 172 173 174 175 176 177
	packet.omegaIx = omegaIx;
	packet.omegaIy = omegaIy;
	packet.omegaIz = omegaIz;
	packet.accel_weight = accel_weight;
	packet.renorm_val = renorm_val;
	packet.error_rp = error_rp;
	packet.error_yaw = error_yaw;

178
	_mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AHRS, (const char *)&packet, 28, 127);
pixhawk's avatar
pixhawk committed
179 180 181 182 183
#endif
}

#endif

184
// MESSAGE AHRS UNPACKING
pixhawk's avatar
pixhawk committed
185 186 187


/**
188
 * @brief Get field omegaIx from ahrs message
pixhawk's avatar
pixhawk committed
189 190 191
 *
 * @return X gyro drift estimate rad/s
 */
192
static inline float mavlink_msg_ahrs_get_omegaIx(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
193 194 195 196 197
{
	return _MAV_RETURN_float(msg,  0);
}

/**
198
 * @brief Get field omegaIy from ahrs message
pixhawk's avatar
pixhawk committed
199 200 201
 *
 * @return Y gyro drift estimate rad/s
 */
202
static inline float mavlink_msg_ahrs_get_omegaIy(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
203 204 205 206 207
{
	return _MAV_RETURN_float(msg,  4);
}

/**
208
 * @brief Get field omegaIz from ahrs message
pixhawk's avatar
pixhawk committed
209 210 211
 *
 * @return Z gyro drift estimate rad/s
 */
212
static inline float mavlink_msg_ahrs_get_omegaIz(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
213 214 215 216 217
{
	return _MAV_RETURN_float(msg,  8);
}

/**
218
 * @brief Get field accel_weight from ahrs message
pixhawk's avatar
pixhawk committed
219 220 221
 *
 * @return average accel_weight
 */
222
static inline float mavlink_msg_ahrs_get_accel_weight(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
223 224 225 226 227
{
	return _MAV_RETURN_float(msg,  12);
}

/**
228
 * @brief Get field renorm_val from ahrs message
pixhawk's avatar
pixhawk committed
229 230 231
 *
 * @return average renormalisation value
 */
232
static inline float mavlink_msg_ahrs_get_renorm_val(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
233 234 235 236 237
{
	return _MAV_RETURN_float(msg,  16);
}

/**
238
 * @brief Get field error_rp from ahrs message
pixhawk's avatar
pixhawk committed
239 240 241
 *
 * @return average error_roll_pitch value
 */
242
static inline float mavlink_msg_ahrs_get_error_rp(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
243 244 245 246 247
{
	return _MAV_RETURN_float(msg,  20);
}

/**
248
 * @brief Get field error_yaw from ahrs message
pixhawk's avatar
pixhawk committed
249 250 251
 *
 * @return average error_yaw value
 */
252
static inline float mavlink_msg_ahrs_get_error_yaw(const mavlink_message_t* msg)
pixhawk's avatar
pixhawk committed
253 254 255 256 257
{
	return _MAV_RETURN_float(msg,  24);
}

/**
258
 * @brief Decode a ahrs message into a struct
pixhawk's avatar
pixhawk committed
259 260
 *
 * @param msg The message to decode
261
 * @param ahrs C-struct to decode the message contents into
pixhawk's avatar
pixhawk committed
262
 */
263
static inline void mavlink_msg_ahrs_decode(const mavlink_message_t* msg, mavlink_ahrs_t* ahrs)
pixhawk's avatar
pixhawk committed
264 265
{
#if MAVLINK_NEED_BYTE_SWAP
266 267 268 269 270 271 272
	ahrs->omegaIx = mavlink_msg_ahrs_get_omegaIx(msg);
	ahrs->omegaIy = mavlink_msg_ahrs_get_omegaIy(msg);
	ahrs->omegaIz = mavlink_msg_ahrs_get_omegaIz(msg);
	ahrs->accel_weight = mavlink_msg_ahrs_get_accel_weight(msg);
	ahrs->renorm_val = mavlink_msg_ahrs_get_renorm_val(msg);
	ahrs->error_rp = mavlink_msg_ahrs_get_error_rp(msg);
	ahrs->error_yaw = mavlink_msg_ahrs_get_error_yaw(msg);
pixhawk's avatar
pixhawk committed
273
#else
274
	memcpy(ahrs, _MAV_PAYLOAD(msg), 28);
pixhawk's avatar
pixhawk committed
275 276
#endif
}