gnsspublisher.h
Go to the documentation of this file.
1 
2 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification,
6 // are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions, and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions, and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the names of the copyright holders nor the names of their contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
24 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
26 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
28 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
29 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
30 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
31 //
32 
33 #ifndef GNSSPUBLISHER_H
34 #define GNSSPUBLISHER_H
35 
36 #include "packetcallback.h"
37 #include <sensor_msgs/NavSatFix.h>
38 
39 #define FIX_TYPE_2D_FIX (2)
40 #define FIX_TYPE_3D_FIX (3)
41 #define FIX_TYPE_GNSS_AND_DEAD_RECKONING (4)
42 
44 {
46  std::string frame_id = DEFAULT_FRAME_ID;
47 
49  {
50  int pub_queue_size = 5;
51  ros::param::get("~publisher_queue_size", pub_queue_size);
52  pub = node.advertise<sensor_msgs::NavSatFix>("gnss", pub_queue_size);
53  ros::param::get("~frame_id", frame_id);
54  }
55 
56  void operator()(const XsDataPacket &packet, ros::Time timestamp)
57  {
58  if (packet.containsRawGnssPvtData())
59  {
60  sensor_msgs::NavSatFix msg;
61 
62  msg.header.stamp = timestamp;
63  msg.header.frame_id = frame_id;
64 
65  XsRawGnssPvtData gnss = packet.rawGnssPvtData();
66 
67  msg.latitude = (double)gnss.m_lat * 1e-7;
68  msg.longitude = (double)gnss.m_lon * 1e-7;
69  msg.altitude = (double)gnss.m_height * 1e-3;
70  // Position covariance [m^2], ENU
71  double sh = ((double)gnss.m_hAcc * 1e-3);
72  double sv = ((double)gnss.m_vAcc * 1e-3);
73  msg.position_covariance = {sh * sh, 0, 0, 0, sh * sh, 0, 0, 0, sv * sv};
74  msg.position_covariance_type = sensor_msgs::NavSatFix::COVARIANCE_TYPE_DIAGONAL_KNOWN;
75 
76  switch (gnss.m_fixType)
77  {
78  case FIX_TYPE_2D_FIX: // fall through
79  case FIX_TYPE_3D_FIX: // fall through
81  msg.status.status = sensor_msgs::NavSatStatus::STATUS_FIX;
82  break;
83  default:
84  msg.status.status = sensor_msgs::NavSatStatus::STATUS_NO_FIX;
85  }
86  msg.status.service = 0; // unknown
87 
88  pub.publish(msg);
89  }
90  }
91 };
92 
93 #endif
GnssPublisher::frame_id
std::string frame_id
Definition: gnsspublisher.h:46
FIX_TYPE_2D_FIX
#define FIX_TYPE_2D_FIX
Definition: gnsspublisher.h:39
msg
msg
ros::Publisher
GnssPublisher::operator()
void operator()(const XsDataPacket &packet, ros::Time timestamp)
Definition: gnsspublisher.h:56
ros::param::get
ROSCPP_DECL bool get(const std::string &key, bool &b)
DEFAULT_FRAME_ID
const char * DEFAULT_FRAME_ID
Definition: packetcallback.h:39
FIX_TYPE_GNSS_AND_DEAD_RECKONING
#define FIX_TYPE_GNSS_AND_DEAD_RECKONING
Definition: gnsspublisher.h:41
packetcallback.h
XsDataPacket
Contains an interpreted data message. The class provides easy access to the contained data through it...
Definition: xsdatapacket.h:301
ros::Publisher::publish
void publish(const boost::shared_ptr< M > &message) const
XsRawGnssPvtData::m_lat
int32_t m_lat
Latitude (deg) (scaling 1e-7)
Definition: xsrawgnsspvtdata.h:170
ros::NodeHandle::advertise
Publisher advertise(AdvertiseOptions &ops)
XsRawGnssPvtData
A container for GNSS Position Velocity and Time data.
Definition: xsrawgnsspvtdata.h:134
XsRawGnssPvtData::m_fixType
uint8_t m_fixType
Definition: xsrawgnsspvtdata.h:150
GnssPublisher::pub
ros::Publisher pub
Definition: gnsspublisher.h:45
GnssPublisher
Definition: gnsspublisher.h:43
XsRawGnssPvtData::m_vAcc
uint32_t m_vAcc
Vertical accuracy estimate (mm)
Definition: xsrawgnsspvtdata.h:175
ros::Time
XsRawGnssPvtData::m_lon
int32_t m_lon
Longitude (deg) (scaling 1e-7)
Definition: xsrawgnsspvtdata.h:169
PacketCallback
Definition: packetcallback.h:41
XsRawGnssPvtData::m_height
int32_t m_height
Height above ellipsoid (mm)
Definition: xsrawgnsspvtdata.h:171
XsRawGnssPvtData::m_hAcc
uint32_t m_hAcc
Horizontal accuracy estimate (mm)
Definition: xsrawgnsspvtdata.h:174
FIX_TYPE_3D_FIX
#define FIX_TYPE_3D_FIX
Definition: gnsspublisher.h:40
GnssPublisher::GnssPublisher
GnssPublisher(ros::NodeHandle &node)
Definition: gnsspublisher.h:48
ros::NodeHandle


xsens_mti_driver
Author(s):
autogenerated on Sun Sep 3 2023 02:43:20