Apollo 10.0
自动驾驶开放平台
imu_msg_converter.cc
浏览该文件的文档.
1/******************************************************************************
2 * Copyright 2023 The Apollo Authors. All Rights Reserved.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *****************************************************************************/
16
19
20namespace apollo {
21namespace cyber {
22
26#ifdef ENABLE_ROS_MSG
27 auto ros_imu_ptr = std::get<0>(in.values);
28 auto& ros_imu = (*ros_imu_ptr);
29
30 auto imu_msg = std::get<0>(out.values);
31 auto corrected_imu_msg = std::get<1>(out.values);
32
33 // ros header time is unix time,
34 // while measurement_time of apollo imu is gps time
35 double unix_msg_time =
36 ros_imu.header.stamp.sec + ros_imu.header.stamp.nanosec / 1e9;
37 imu_msg->mutable_header()->set_timestamp_sec(unix_msg_time);
38 imu_msg->mutable_header()->set_module_name("gnss");
39
40 imu_msg->set_measurement_time(unix_msg_time);
41 imu_msg->set_measurement_span(0.0);
42 imu_msg->mutable_linear_acceleration()->set_x(ros_imu.linear_acceleration.x);
43 imu_msg->mutable_linear_acceleration()->set_y(ros_imu.linear_acceleration.y);
44 imu_msg->mutable_linear_acceleration()->set_z(ros_imu.linear_acceleration.z);
45 imu_msg->mutable_angular_velocity()->set_x(ros_imu.angular_velocity.x);
46 imu_msg->mutable_angular_velocity()->set_y(ros_imu.angular_velocity.y);
47 imu_msg->mutable_angular_velocity()->set_z(ros_imu.angular_velocity.z);
48
49 corrected_imu_msg->mutable_header()->set_timestamp_sec(unix_msg_time);
50 corrected_imu_msg->mutable_header()->set_module_name("gnss");
51 corrected_imu_msg->mutable_imu()->mutable_linear_acceleration()->set_x(
52 ros_imu.linear_acceleration.x);
53 corrected_imu_msg->mutable_imu()->mutable_linear_acceleration()->set_y(
54 ros_imu.linear_acceleration.y);
55 corrected_imu_msg->mutable_imu()->mutable_linear_acceleration()->set_z(
56 ros_imu.linear_acceleration.z);
57 corrected_imu_msg->mutable_imu()->mutable_angular_velocity()->set_x(
58 ros_imu.angular_velocity.x);
59 corrected_imu_msg->mutable_imu()->mutable_angular_velocity()->set_y(
60 ros_imu.angular_velocity.y);
61 corrected_imu_msg->mutable_imu()->mutable_angular_velocity()->set_z(
62 ros_imu.angular_velocity.z);
63 double quaternion[4];
64 double euler_angles[3];
65
66 quaternion[0] = ros_imu.orientation.x;
67 quaternion[1] = ros_imu.orientation.y;
68 quaternion[2] = ros_imu.orientation.z;
69 quaternion[3] = ros_imu.orientation.w;
70
71 QuaternionToEuler(quaternion, euler_angles);
72 auto heading = QuaternionToHeading(euler_angles[2]);
73 corrected_imu_msg->mutable_imu()->mutable_euler_angles()->set_x(
74 euler_angles[0]);
75 corrected_imu_msg->mutable_imu()->mutable_euler_angles()->set_y(
76 euler_angles[1]);
77 corrected_imu_msg->mutable_imu()->mutable_euler_angles()->set_z(
78 euler_angles[2]);
79
80#endif
81 return true;
82}
83
84} // namespace cyber
85} // namespace apollo
virtual bool ConvertMsg(InputTypes< RosImuMsgPtr > &, OutputTypes< ImuMsgPtr, CorrectedImuMsgPtr > &)
convert the message between ros and apollo
double QuaternionToHeading(double yaw)
void QuaternionToEuler(const double quaternion[4], double att[3])
class register implement
Definition arena_queue.h:37
std::tuple< Types... > values
std::tuple< Types... > values