21 using namespace std::literals;
23 #if MRPT_HAS_xSENS_MT3
39 #define cmt3 (*static_cast<xsens::Cmt3*>(m_cmt3_ptr))
40 #define deviceId (*static_cast<CmtDeviceId*>(m_deviceId_ptr))
43 #if MRPT_HAS_xSENS_MT3
44 #ifdef MRPT_OS_WINDOWS
46 #if defined(_MSC_VER) || defined(__BORLANDC__)
47 #pragma comment(lib, "SetupAPI.lib")
55 CIMUXSens::CIMUXSens()
62 m_deviceId_ptr(nullptr),
66 #if MRPT_HAS_xSENS_MT3
72 "MRPT has been compiled with 'BUILD_XSENS_MT3'=OFF, so this class "
82 #if MRPT_HAS_xSENS_MT3
97 #if MRPT_HAS_xSENS_MT3
101 std::this_thread::sleep_for(200ms);
108 unsigned int cont = 0;
116 res =
cmt3.waitForDataMessage(&packet);
125 mrpt::make_aligned_shared<CObservationIMU>();
133 obs->dataIsPresent[
IMU_YAW] =
true;
137 obs->dataIsPresent[
IMU_ROLL] =
true;
193 if (
cmt3.isPortOpen())
cmt3.closePort();
195 std::cerr <<
"[CIMUXSens::doProcess()] Error: No data "
196 "available [XRV_TIMEOUT]"
214 "MRPT has been compiled with 'BUILD_XSENS_MT3'=OFF, so this class "
224 #if MRPT_HAS_xSENS_MT3
226 if (
cmt3.getBaudrate(baudrate) ==
XRV_OK)
return true;
230 unsigned long portCount = 0;
231 unsigned short mtCount = 0;
235 std::cout <<
"Scanning for connected Xsens devices..." << std::endl;
237 portCount = portInfo.
length();
238 std::cout <<
"Done" << std::endl;
241 std::cout <<
"No xSens device found" << std::endl;
259 std::cout <<
"Using COM port "
260 << portInfo[0].m_portName <<
" at "
261 << portInfo[0].m_baudrate <<
" baud" << std::endl;
262 std::cout <<
"Opening port..." << std::endl;
265 res =
cmt3.openPort(portInfo[0].m_portName, portInfo[0].m_baudrate);
268 std::cerr <<
"COM Port could not be opened" << std::endl;
272 std::cout <<
"done" << std::endl;
276 <<
"Retrieving MotionTracker count (excluding attached Xbus Master(s))"
278 mtCount =
cmt3.getMtCount();
279 std::cout <<
"MotionTracker count: " << mtCount << std::endl;
284 std::cout <<
"Retrieving MotionTracker device ID" << std::endl;
286 std::cout <<
"Device ID at busId 1: " << (long)
deviceId
291 std::cerr <<
"Device ID could not be gathered" << std::endl;
307 #if MRPT_HAS_xSENS_MT3
311 if (
cmt3.isPortOpen())
return;
319 std::cerr <<
"Error Could not initialize the device" << std::endl;
323 std::cout <<
"xSens IMU detected and connected" << std::endl;
334 std::cerr <<
"An error ocurred when setting the device to config mode"
339 unsigned short sampleFreq;
340 sampleFreq =
cmt3.getSampleFrequency();
343 std::cout <<
"Configuring mode selection" << std::endl;
349 std::cerr <<
"An error ocurred when configuring the device"
360 <<
"An error ocurred when setting the device to measurement mode"
365 std::cout <<
"Getting initial TimeStamp" << std::endl;
370 res =
cmt3.waitForDataMessage(&packet);
378 std::cout <<
"Gathering data" << std::endl;
383 "MRPT has been compiled with 'BUILD_XSENS_MT3'=OFF, so this class "
396 configSource.
read_float(iniSection,
"pose_x", 0,
false),
397 configSource.
read_float(iniSection,
"pose_y", 0,
false),
398 configSource.
read_float(iniSection,
"pose_z", 0,
false),
406 #ifdef MRPT_OS_WINDOWS
#define IMPLEMENTS_GENERIC_SENSOR(class_name, NameSpace)
This must be inserted in all CGenericSensor classes implementation files:
std::string m_sensorLabel
See CGenericSensor.
void appendObservation(const mrpt::utils::CSerializable::Ptr &obj)
Like appendObservations() but for just one observation.
A class for interfacing XSens 3rd generation Inertial Measuring Units (IMUs), the "XSens MTi" model.
void doProcess()
This method will be invoked at a minimum rate of "process_rate" (Hz)
mrpt::system::TTimeStamp m_timeStartTT
mrpt::poses::CPose3D m_sensorPose
bool searchPortAndConnect()
Search the port where the sensor is located and connect to it.
int m_COMbauds
This serial port will be attempted to be opened automatically when this class is first used to reques...
virtual ~CIMUXSens()
Destructor.
void initialize()
Turns on the xSens device and configure it for getting orientation data.
void loadConfig_sensorSpecific(const mrpt::utils::CConfigFileBase &configSource, const std::string &iniSection)
See the class documentation at the top for expected parameters.
unsigned int m_toutCounter
Timeout counter (for internal use only)
std::shared_ptr< CObservationIMU > Ptr
void setFromValues(const double x0, const double y0, const double z0, const double yaw=0, const double pitch=0, const double roll=0)
Set the pose from a 3D position (meters) and yaw/pitch/roll angles (radians) - This method recomputes...
This class allows loading and storing values and vectors of different types from a configuration text...
std::string read_string(const std::string §ion, const std::string &name, const std::string &defaultValue, bool failIfNotFound=false) const
int read_int(const std::string §ion, const std::string &name, int defaultValue, bool failIfNotFound=false) const
float read_float(const std::string §ion, const std::string &name, float defaultValue, bool failIfNotFound=false) const
High-level communication class.
void append(const T &item)
Adds an item to the end of the list.
uint32_t length(void) const
Returns the number of items currently in the list.
A structure containing MT data + timestamp and formatting information.
bool containsOriEuler(const uint16_t index=0) const
Check if data item contains Euler Orientation data.
bool containsCalGyr(const uint16_t index=0) const
Check if data item contains Calibrated Gyroscope data.
bool containsCalAcc(const uint16_t index=0) const
Check if data item contains Calibrated Accelerometer data.
CmtTimeStamp getRtc(const uint16_t index=0) const
Return the RTC of the packet.
CmtVector getCalGyr(const uint16_t index=0) const
Return the Calibrated Gyroscope component of a data item.
CmtVector getCalAcc(const uint16_t index=0) const
Return the Calibrated Accelerometer component of a data item.
CmtEuler getOriEuler(const uint16_t index=0) const
Return the Orientation component of a data item as Euler angles.
uint32_t CmtDeviceId
The type of a Device Id.
#define CMT_OUTPUTSETTINGS_CALIBMODE_ACCGYR
#define CMT_OUTPUTSETTINGS_ORIENTMODE_EULER
uint64_t CmtOutputSettings
An output settings bit-field.
#define CMT_OUTPUTMODE_CALIB
uint32_t CmtOutputMode
An output mode bit-field.
#define CMT_OUTPUTMODE_ORIENT
#define CMT_OUTPUTSETTINGS_TIMESTAMP_SAMPLECNT
GLsizei const GLchar ** string
@ IMU_X_ACC
x-axis acceleration (local/vehicle frame) (m/sec2)
@ IMU_PITCH_VEL
pitch angular velocity (local/vehicle frame) (rad/sec)
@ IMU_PITCH
orientation pitch absolute value (global/navigation frame) (rad)
@ IMU_YAW
orientation yaw absolute value (global/navigation frame) (rad)
@ IMU_Z_ACC
z-axis acceleration (local/vehicle frame) (m/sec2)
@ IMU_ROLL_VEL
roll angular velocity (local/vehicle frame) (rad/sec)
@ IMU_YAW_VEL
yaw angular velocity (local/vehicle frame) (rad/sec)
@ IMU_Y_ACC
y-axis acceleration (local/vehicle frame) (m/sec2)
@ IMU_ROLL
orientation roll absolute value (global/navigation frame) (rad)
char * strcpy(char *dest, size_t destSize, const char *source) noexcept
An OS-independent version of strcpy.
mrpt::system::TTimeStamp now()
A shortcut for system::getCurrentTime.
#define THROW_EXCEPTION(msg)
Contains classes for various device interfaces.
This namespace contains representation of robot actions and observations.
Classes for serialization, sockets, ini-file manipulation, streams, list of properties-values,...
bool cmtScanPorts(List< CmtPortInfo > &ports, uint32_t baudrate, uint32_t singleScanTimeout, uint32_t scanTries)
Scan COM ports for connected Xsens devices.
unsigned __int32 uint32_t
unsigned __int64 uint64_t
A structure for storing device modes.
double m_yaw
The yaw (rotation around z-axis / down-up-line)
double m_pitch
The pitch (rotation around y-axis / right-left-line)
double m_roll
The roll (rotation around x-axis / back-front-line)
Structure for storing information about a serial port.
char m_portName[270]
The port name.
uint32_t m_baudrate
The baudrate at which an Xsens device was detected.
XsensResultValue
Xsens return values.
@ XRV_OK
Operation was performed successfully.