32 #include <boost/make_shared.hpp>
46 novatel_gps_msgs::InscovPtr
49 if (bin_msg.data_.size() != BINARY_LENGTH)
51 std::stringstream error;
52 error <<
"Unexpected inscov message size: " << bin_msg.data_.size();
55 novatel_gps_msgs::InscovPtr ros_msg = boost::make_shared<novatel_gps_msgs::Inscov>();
57 ros_msg->novatel_msg_header = h_parser.
ParseBinary(bin_msg);
58 ros_msg->novatel_msg_header.message_name = GetMessageName();
63 for (
int i = 0; i < 9; i++, offset += 8)
65 ros_msg->position_covariance[i] =
ParseDouble(&bin_msg.data_[offset]);
67 for (
int i = 0; i < 9; i++, offset += 8)
69 ros_msg->attitude_covariance[i] =
ParseDouble(&bin_msg.data_[offset]);
71 for (
int i = 0; i < 9; i++, offset += 8)
73 ros_msg->velocity_covariance[i] =
ParseDouble(&bin_msg.data_[offset]);
78 novatel_gps_msgs::InscovPtr
81 if (sentence.body.size() != ASCII_FIELDS)
83 std::stringstream error;
84 error <<
"Unexpected number of fields in INSCOV log: " << sentence.body.size();
87 novatel_gps_msgs::InscovPtr ros_msg = boost::make_shared<novatel_gps_msgs::Inscov>();
89 ros_msg->novatel_msg_header = h_parser.
ParseAscii(sentence);
93 valid &=
ParseUInt32(sentence.body[0], ros_msg->week);
94 valid &=
ParseDouble(sentence.body[1], ros_msg->seconds);
97 for (
int i = 0; i < 9; i++, offset++)
99 valid &=
ParseDouble(sentence.body[offset], ros_msg->position_covariance[i]);
101 for (
int i = 0; i < 9; i++, offset++)
103 valid &=
ParseDouble(sentence.body[offset], ros_msg->attitude_covariance[i]);
105 for (
int i = 0; i < 9; i++, offset++)
107 valid &=
ParseDouble(sentence.body[offset], ros_msg->velocity_covariance[i]);