mavlink_msg_sensor_bias.h 7.47 KB
Newer Older
James Goppert's avatar
James Goppert committed
1 2 3
// MESSAGE SENSOR_BIAS PACKING

#define MAVLINK_MSG_ID_SENSOR_BIAS 172
lm's avatar
lm committed
4 5
#define MAVLINK_MSG_ID_SENSOR_BIAS_LEN 24
#define MAVLINK_MSG_172_LEN 24
James Goppert's avatar
James Goppert committed
6 7 8 9 10 11 12 13 14 15 16 17 18

typedef struct __mavlink_sensor_bias_t 
{
	float axBias; ///< Accelerometer X bias (m/s)
	float ayBias; ///< Accelerometer Y bias (m/s)
	float azBias; ///< Accelerometer Z bias (m/s)
	float gxBias; ///< Gyro X bias (rad/s)
	float gyBias; ///< Gyro Y bias (rad/s)
	float gzBias; ///< Gyro Z bias (rad/s)

} mavlink_sensor_bias_t;

/**
James Goppert's avatar
James Goppert committed
19 20 21 22
 * @brief Pack a sensor_bias message
 * @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
James Goppert's avatar
James Goppert committed
23 24 25 26 27 28 29 30 31 32 33
 *
 * @param axBias Accelerometer X bias (m/s)
 * @param ayBias Accelerometer Y bias (m/s)
 * @param azBias Accelerometer Z bias (m/s)
 * @param gxBias Gyro X bias (rad/s)
 * @param gyBias Gyro Y bias (rad/s)
 * @param gzBias Gyro Z bias (rad/s)
 * @return length of the message in bytes (excluding serial stream start sign)
 */
static inline uint16_t mavlink_msg_sensor_bias_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, float axBias, float ayBias, float azBias, float gxBias, float gyBias, float gzBias)
{
lm's avatar
lm committed
34
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
James Goppert's avatar
James Goppert committed
35 36
	msg->msgid = MAVLINK_MSG_ID_SENSOR_BIAS;

lm's avatar
lm committed
37 38 39 40 41 42
	p->axBias = axBias; // float:Accelerometer X bias (m/s)
	p->ayBias = ayBias; // float:Accelerometer Y bias (m/s)
	p->azBias = azBias; // float:Accelerometer Z bias (m/s)
	p->gxBias = gxBias; // float:Gyro X bias (rad/s)
	p->gyBias = gyBias; // float:Gyro Y bias (rad/s)
	p->gzBias = gzBias; // float:Gyro Z bias (rad/s)
James Goppert's avatar
James Goppert committed
43

lm's avatar
lm committed
44
	return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_SENSOR_BIAS_LEN);
James Goppert's avatar
James Goppert committed
45 46
}

James Goppert's avatar
James Goppert committed
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
/**
 * @brief Pack a sensor_bias message
 * @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 axBias Accelerometer X bias (m/s)
 * @param ayBias Accelerometer Y bias (m/s)
 * @param azBias Accelerometer Z bias (m/s)
 * @param gxBias Gyro X bias (rad/s)
 * @param gyBias Gyro Y bias (rad/s)
 * @param gzBias Gyro Z bias (rad/s)
 * @return length of the message in bytes (excluding serial stream start sign)
 */
static inline uint16_t mavlink_msg_sensor_bias_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, float axBias, float ayBias, float azBias, float gxBias, float gyBias, float gzBias)
James Goppert's avatar
James Goppert committed
62
{
lm's avatar
lm committed
63
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
James Goppert's avatar
James Goppert committed
64 65
	msg->msgid = MAVLINK_MSG_ID_SENSOR_BIAS;

lm's avatar
lm committed
66 67 68 69 70 71
	p->axBias = axBias; // float:Accelerometer X bias (m/s)
	p->ayBias = ayBias; // float:Accelerometer Y bias (m/s)
	p->azBias = azBias; // float:Accelerometer Z bias (m/s)
	p->gxBias = gxBias; // float:Gyro X bias (rad/s)
	p->gyBias = gyBias; // float:Gyro Y bias (rad/s)
	p->gzBias = gzBias; // float:Gyro Z bias (rad/s)
James Goppert's avatar
James Goppert committed
72

lm's avatar
lm committed
73
	return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_SENSOR_BIAS_LEN);
James Goppert's avatar
James Goppert committed
74 75
}

James Goppert's avatar
James Goppert committed
76 77 78 79 80 81 82 83
/**
 * @brief Encode a sensor_bias struct into a message
 *
 * @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 sensor_bias C-struct to read the message contents from
 */
James Goppert's avatar
James Goppert committed
84 85 86 87 88
static inline uint16_t mavlink_msg_sensor_bias_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_sensor_bias_t* sensor_bias)
{
	return mavlink_msg_sensor_bias_pack(system_id, component_id, msg, sensor_bias->axBias, sensor_bias->ayBias, sensor_bias->azBias, sensor_bias->gxBias, sensor_bias->gyBias, sensor_bias->gzBias);
}

James Goppert's avatar
James Goppert committed
89 90 91 92 93 94 95 96 97 98 99
/**
 * @brief Send a sensor_bias message
 * @param chan MAVLink channel to send the message
 *
 * @param axBias Accelerometer X bias (m/s)
 * @param ayBias Accelerometer Y bias (m/s)
 * @param azBias Accelerometer Z bias (m/s)
 * @param gxBias Gyro X bias (rad/s)
 * @param gyBias Gyro Y bias (rad/s)
 * @param gzBias Gyro Z bias (rad/s)
 */
lm's avatar
lm committed
100 101


102
#ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
lm's avatar
lm committed
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133
static inline void mavlink_msg_sensor_bias_send(mavlink_channel_t chan, float axBias, float ayBias, float azBias, float gxBias, float gyBias, float gzBias)
{
	mavlink_header_t hdr;
	mavlink_sensor_bias_t payload;
	uint16_t checksum;
	mavlink_sensor_bias_t *p = &payload;

	p->axBias = axBias; // float:Accelerometer X bias (m/s)
	p->ayBias = ayBias; // float:Accelerometer Y bias (m/s)
	p->azBias = azBias; // float:Accelerometer Z bias (m/s)
	p->gxBias = gxBias; // float:Gyro X bias (rad/s)
	p->gyBias = gyBias; // float:Gyro Y bias (rad/s)
	p->gzBias = gzBias; // float:Gyro Z bias (rad/s)

	hdr.STX = MAVLINK_STX;
	hdr.len = MAVLINK_MSG_ID_SENSOR_BIAS_LEN;
	hdr.msgid = MAVLINK_MSG_ID_SENSOR_BIAS;
	hdr.sysid = mavlink_system.sysid;
	hdr.compid = mavlink_system.compid;
	hdr.seq = mavlink_get_channel_status(chan)->current_tx_seq;
	mavlink_get_channel_status(chan)->current_tx_seq = hdr.seq + 1;
	mavlink_send_mem(chan, (uint8_t *)&hdr.STX, MAVLINK_NUM_HEADER_BYTES );

	crc_init(&checksum);
	checksum = crc_calculate_mem((uint8_t *)&hdr.len, &checksum, MAVLINK_CORE_HEADER_LEN);
	checksum = crc_calculate_mem((uint8_t *)&payload, &checksum, hdr.len );
	hdr.ck_a = (uint8_t)(checksum & 0xFF); ///< Low byte
	hdr.ck_b = (uint8_t)(checksum >> 8); ///< High byte

	mavlink_send_mem(chan, (uint8_t *)&payload, hdr.len);
	mavlink_send_mem(chan, (uint8_t *)&hdr.ck_a, MAVLINK_NUM_CHECKSUM_BYTES);
James Goppert's avatar
James Goppert committed
134 135 136 137 138 139 140 141 142 143 144 145
}

#endif
// MESSAGE SENSOR_BIAS UNPACKING

/**
 * @brief Get field axBias from sensor_bias message
 *
 * @return Accelerometer X bias (m/s)
 */
static inline float mavlink_msg_sensor_bias_get_axBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
146 147
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->axBias);
James Goppert's avatar
James Goppert committed
148 149 150 151 152 153 154 155 156
}

/**
 * @brief Get field ayBias from sensor_bias message
 *
 * @return Accelerometer Y bias (m/s)
 */
static inline float mavlink_msg_sensor_bias_get_ayBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
157 158
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->ayBias);
James Goppert's avatar
James Goppert committed
159 160 161 162 163 164 165 166 167
}

/**
 * @brief Get field azBias from sensor_bias message
 *
 * @return Accelerometer Z bias (m/s)
 */
static inline float mavlink_msg_sensor_bias_get_azBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
168 169
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->azBias);
James Goppert's avatar
James Goppert committed
170 171 172 173 174 175 176 177 178
}

/**
 * @brief Get field gxBias from sensor_bias message
 *
 * @return Gyro X bias (rad/s)
 */
static inline float mavlink_msg_sensor_bias_get_gxBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
179 180
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->gxBias);
James Goppert's avatar
James Goppert committed
181 182 183 184 185 186 187 188 189
}

/**
 * @brief Get field gyBias from sensor_bias message
 *
 * @return Gyro Y bias (rad/s)
 */
static inline float mavlink_msg_sensor_bias_get_gyBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
190 191
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->gyBias);
James Goppert's avatar
James Goppert committed
192 193 194 195 196 197 198 199 200
}

/**
 * @brief Get field gzBias from sensor_bias message
 *
 * @return Gyro Z bias (rad/s)
 */
static inline float mavlink_msg_sensor_bias_get_gzBias(const mavlink_message_t* msg)
{
lm's avatar
lm committed
201 202
	mavlink_sensor_bias_t *p = (mavlink_sensor_bias_t *)&msg->payload[0];
	return (float)(p->gzBias);
James Goppert's avatar
James Goppert committed
203 204
}

James Goppert's avatar
James Goppert committed
205 206 207 208 209 210
/**
 * @brief Decode a sensor_bias message into a struct
 *
 * @param msg The message to decode
 * @param sensor_bias C-struct to decode the message contents into
 */
James Goppert's avatar
James Goppert committed
211 212
static inline void mavlink_msg_sensor_bias_decode(const mavlink_message_t* msg, mavlink_sensor_bias_t* sensor_bias)
{
lm's avatar
lm committed
213
	memcpy( sensor_bias, msg->payload, sizeof(mavlink_sensor_bias_t));
James Goppert's avatar
James Goppert committed
214
}