MIP_SDK
v3.0.0
MicroStrain Communications Library for embedded systems
|
Go to the documentation of this file.
21 "Suppress the usual ACK/NACK reply.",
24 {
true,
false,
false,
false,
false},
30 "Number of descriptors in the descriptor list.",
33 {
true,
false,
false,
false,
false},
42 {
true,
false,
false,
false,
false},
49 "commands_3dm::PollImuMessage",
51 "Poll the device for an IMU message with the specified format\n\nThis function polls for an IMU message using the provided format. The resulting message\nwill maintain the order of descriptors sent in the command and any unrecognized\ndescriptors are ignored. If the format is not provided, the device will attempt to use the\nstored format (set with the Set IMU Message Format command.) If no format is provided\nand there is no stored format, the device will respond with a NACK. The reply packet contains\nan ACK/NACK field. The polled data packet is sent separately as an IMU Data packet.",
68 "Suppress the usual ACK/NACK reply.",
71 {
true,
false,
false,
false,
false},
77 "Number of descriptors in the descriptor list.",
80 {
true,
false,
false,
false,
false},
89 {
true,
false,
false,
false,
false},
96 "commands_3dm::PollGnssMessage",
98 "Poll the device for an GNSS message with the specified format\n\nThis function polls for a GNSS message using the provided format. The resulting message\nwill maintain the order of descriptors sent in the command and any unrecognized\ndescriptors are ignored. If the format is not provided, the device will attempt to use the\nstored format (set with the Set GNSS Message Format command.) If no format is provided\nand there is no stored format, the device will respond with a NACK. The reply packet contains\nan ACK/NACK field. The polled data packet is sent separately as a GNSS Data packet.",
115 "Suppress the usual ACK/NACK reply.",
118 {
true,
false,
false,
false,
false},
124 "Number of descriptors in the format list.",
127 {
true,
false,
false,
false,
false},
133 "Descriptor format list.",
136 {
true,
false,
false,
false,
false},
143 "commands_3dm::PollFilterMessage",
144 "poll_filter_message",
145 "Poll the device for an Estimation Filter message with the specified format\n\nThis function polls for an Estimation Filter message using the provided format. The resulting message\nwill maintain the order of descriptors sent in the command and any unrecognized\ndescriptors are ignored. If the format is not provided, the device will attempt to use the\nstored format (set with the Set Estimation Filter Message Format command.) If no format is provided\nand there is no stored format, the device will respond with a NACK. The reply packet contains\nan ACK/NACK field. The polled data packet is sent separately as an Estimation Filter Data packet.",
162 "Number of descriptors",
165 {
true,
false,
false,
false,
false},
171 "Descriptor format list.",
174 {
true,
false,
false,
false,
false},
181 "commands_3dm::ImuMessageFormat::Response",
198 FUNCTION_SELECTOR_PARAM,
201 "Number of descriptors",
204 {
true,
false,
false,
false,
false},
210 "Descriptor format list.",
213 {
true,
false,
false,
false,
false},
220 "commands_3dm::ImuMessageFormat",
221 "imu_message_format",
222 "Set, read, or save the format of the IMU data packet.\n\nThe resulting data messages will maintain the order of descriptors sent in the command.",
225 {
true,
true,
true,
true,
true},
239 "Number of descriptors",
242 {
true,
false,
false,
false,
false},
248 "Descriptor format list.",
251 {
true,
false,
false,
false,
false},
258 "commands_3dm::GpsMessageFormat::Response",
275 FUNCTION_SELECTOR_PARAM,
278 "Number of descriptors",
281 {
true,
false,
false,
false,
false},
287 "Descriptor format list.",
290 {
true,
false,
false,
false,
false},
297 "commands_3dm::GpsMessageFormat",
298 "gps_message_format",
299 "Set, read, or save the format of the GNSS data packet.\n\nThe resulting data messages will maintain the order of descriptors sent in the command.",
302 {
true,
true,
true,
true,
true},
316 "Number of descriptors (limited by payload size)",
319 {
true,
false,
false,
false,
false},
328 {
true,
false,
false,
false,
false},
335 "commands_3dm::FilterMessageFormat::Response",
352 FUNCTION_SELECTOR_PARAM,
355 "Number of descriptors (limited by payload size)",
358 {
true,
false,
false,
false,
false},
367 {
true,
false,
false,
false,
false},
374 "commands_3dm::FilterMessageFormat",
375 "filter_message_format",
376 "Set, read, or save the format of the Estimation Filter data packet.\n\nThe resulting data messages will maintain the order of descriptors sent in the command.",
379 {
true,
true,
true,
true,
true},
396 {
true,
false,
false,
false,
false},
403 "commands_3dm::ImuGetBaseRate::Response",
420 "commands_3dm::ImuGetBaseRate",
421 "Get IMU Data Base Rate",
422 "Get the base rate for the IMU data in Hz\n\nThis is the fastest rate for this type of data available on the device.\nThis is used in conjunction with the IMU Message Format Command to set streaming data at a specified rate.",
442 {
true,
false,
false,
false,
false},
449 "commands_3dm::GpsGetBaseRate::Response",
466 "commands_3dm::GpsGetBaseRate",
467 "Get GNSS Data Base Rate",
468 "Get the base rate for the GNSS data in Hz\n\nThis is the fastest rate for this type of data available on the device.\nThis is used in conjunction with the GNSS Message Format Command to set streaming data at a specified rate.",
488 {
true,
false,
false,
false,
false},
495 "commands_3dm::FilterGetBaseRate::Response",
512 "commands_3dm::FilterGetBaseRate",
513 "Get Estimation Filter Data Base Rate",
514 "Get the base rate for the Estimation Filter data in Hz\n\nThis is the fastest rate for this type of data available on the device.\nThis is used in conjunction with the Estimation Filter Message Format Command to set streaming data at a specified rate.",
531 "Data descriptor set. Must be supported.",
534 {
true,
false,
false,
false,
false},
540 "Suppress the usual ACK/NACK reply.",
543 {
true,
false,
false,
false,
false},
549 "Number of descriptors in the format list.",
552 {
true,
false,
false,
false,
false},
558 "Descriptor format list.",
561 {
true,
false,
false,
false,
false},
568 "commands_3dm::PollData",
570 "Poll the device for a message with the specified descriptor set and format.\n\nThis function polls for a message using the provided format. The resulting message\nwill maintain the order of descriptors sent in the command and any unrecognized\ndescriptors are ignored. If the format is not provided, the device will attempt to use the\nstored format (set with the Set Message Format command.) If no format is provided\nand there is no stored format, the device will respond with a NACK. The reply packet contains\nan ACK/NACK field. The polled data packet is sent separately as a normal Data packet.",
587 "Echoes the parameter in the command.",
590 {
true,
false,
false,
false,
false,
true},
596 "Base rate in Hz (0 = variable, unknown, or user-defined rate. Data will be sent when received).",
599 {
true,
false,
false,
false,
false},
606 "commands_3dm::GetBaseRate::Response",
625 "This is the data descriptor set. It must be a supported descriptor.",
628 {
true,
false,
false,
false,
false,
true},
635 "commands_3dm::GetBaseRate",
636 "Get Data Base Rate",
637 "Get the base rate for the specified descriptor set in Hz.",
654 "Echoes the descriptor set from the command.",
657 {
true,
false,
false,
false,
false,
true},
663 "Number of descriptors in the list.",
666 {
true,
false,
false,
false,
false},
672 "List of descriptors and decimations.",
675 {
true,
false,
false,
false,
false},
682 "commands_3dm::MessageFormat::Response",
699 FUNCTION_SELECTOR_PARAM,
702 "Data descriptor set. Must be supported. When function is SAVE, LOAD, or DEFAULT, can be 0 to apply to all descriptor sets.",
705 {
true,
true,
true,
true,
true,
true},
711 "Number of descriptors (limited by payload size)",
714 {
true,
false,
false,
false,
false},
720 "List of descriptors and decimations.",
723 {
true,
false,
false,
false,
false},
730 "commands_3dm::MessageFormat",
732 "Set, read, or save the format for a given data packet.\n\nThe resulting data messages will maintain the order of descriptors sent in the command.",
735 {
true,
true,
true,
true,
true},
747 { uint32_t(1),
"GGA",
"GPS System Fix Data. Source can be the Filter or GNSS1/2 datasets." },
748 { uint32_t(2),
"GLL",
"Geographic Position Lat/Lon. Source can be the Filter or GNSS1/2 datasets." },
749 { uint32_t(3),
"GSV",
"GNSS Satellites in View. Source must be either GNSS1 or GNSS2 datasets. The talker ID must be set to IGNORED." },
750 { uint32_t(4),
"RMC",
"Recommended Minimum Specific GNSS Data. Source can be the Filter or GNSS1/2 datasets." },
751 { uint32_t(5),
"VTG",
"Course over Ground. Source can be the Filter or GNSS1/2 datasets." },
752 { uint32_t(6),
"HDT",
"Heading, True. Source can be the Filter or GNSS1/2 datasets." },
753 { uint32_t(7),
"ZDA",
"Time & Date. Source must be the GNSS1 or GNSS2 datasets." },
754 { uint32_t(129),
"MSRA",
"MicroStrain proprietary Euler angles. Source must be the Filter dataset. The talker ID must be set to IGNORED." },
755 { uint32_t(130),
"MSRR",
"MicroStrain proprietary Angular Rate/Acceleration. Source must be the Sensor dataset. The talker ID must be set to IGNORED." },
773 { uint32_t(0),
"IGNORED",
"Talker ID cannot be changed." },
774 { uint32_t(1),
"GNSS",
"NMEA message will be produced with talker id 'GN'." },
775 { uint32_t(2),
"GPS",
"NMEA message will be produced with talker id 'GP'." },
776 { uint32_t(3),
"GALILEO",
"NMEA message will be produced with talker id 'GA'." },
777 { uint32_t(4),
"GLONASS",
"NMEA message will be produced with talker id 'GL'." },
797 "NMEA sentence type.",
806 "NMEA talker ID. Ignored for proprietary sentences.",
815 "Data descriptor set where the data will be sourced. Available options depend on the sentence.",
824 "Decimation from the base rate for source_desc_set. Frequency is limited to 10 Hz or the base rate, whichever is lower. Must be 0 when polling.",
849 "Suppress the usual ACK/NACK reply.",
852 {
true,
false,
false,
false,
false},
858 "Number of format entries (limited by payload size)",
861 {
true,
false,
false,
false,
false},
867 "List of format entries.",
870 {
true,
false,
false,
false,
false},
877 "commands_3dm::NmeaPollData",
879 "Poll the device for a NMEA message with the specified format.\n\nThis function polls for a NMEA message using the provided format.\nIf the format is not provided, the device will attempt to use the\nstored format (set with the Set NMEA Message Format command.) If no format is provided\nand there is no stored format, the device will respond with a NACK. The reply packet contains\nan ACK/NACK field. The polled data packet is sent separately as normal NMEA messages.",
896 "Number of format entries (limited by payload size)",
899 {
true,
false,
false,
false,
false},
905 "List of format entries.",
908 {
true,
false,
false,
false,
false},
915 "commands_3dm::NmeaMessageFormat::Response",
932 FUNCTION_SELECTOR_PARAM,
935 "Number of format entries (limited by payload size)",
938 {
true,
false,
false,
false,
false},
944 "List of format entries.",
947 {
true,
false,
false,
false,
false},
954 "commands_3dm::NmeaMessageFormat",
955 "nmea_message_format",
956 "Set, read, or save the NMEA message format.",
959 {
true,
true,
true,
true,
true},
971 FUNCTION_SELECTOR_PARAM,
976 "commands_3dm::DeviceSettings",
978 "Save, Load, or Reset to Default the values for all device settings.\n\nWhen a save current settings command is issued, a brief data disturbance may occur while all settings are written to non-volatile memory.\n\nThis command should have a long timeout as it may take up to 1 second to complete.",
981 {
false,
false,
true,
true,
true},
998 {
true,
false,
false,
false,
false},
1005 "commands_3dm::UartBaudrate::Response",
1022 FUNCTION_SELECTOR_PARAM,
1028 {
true,
false,
false,
false,
false},
1035 "commands_3dm::UartBaudrate",
1037 "Read, Save, Load, or Reset to Default the baud rate of the main communication channel.\n\nFor all functions except 0x01 (use new settings), the new baud rate value is ignored.\nPlease see the device user manual for supported baud rates.\n\nThe device will wait until all incoming and outgoing data has been sent, up\nto a maximum of 250 ms, before applying any change.\n\nNo guarantee is provided as to what happens to commands issued during this\ndelay period; They may or may not be processed and any responses aren't\nguaranteed to be at one rate or the other. The same applies to data packets.\n\nIt is highly recommended that the device be idle before issuing this command\nand that it be issued in its own packet. Users should wait 250 ms after\nsending this command before further interaction.",
1040 {
true,
true,
true,
true,
true},
1052 { uint32_t(0),
"OVERWRITE",
"Replaces the message format(s), removing any existing descriptors." },
1053 { uint32_t(1),
"MERGE",
"Merges support descriptors into existing format(s). May reorder descriptors." },
1054 { uint32_t(2),
"ADD",
"Adds descriptors to the current message format(s) without changing existing descriptors. May result in duplicates." },
1077 {
true,
false,
false,
false,
false},
1083 "Reserved. Set to 0x00.",
1086 {
true,
false,
false,
false,
false},
1093 "commands_3dm::FactoryStreaming",
1094 "factory_streaming",
1095 "Configures the device for recording data for technical support.\n\nThis command will configure all available data streams to predefined\nformats designed to be used with technical support.",
1115 {
true,
false,
false,
false,
false,
true},
1124 {
true,
false,
false,
false,
false},
1131 "commands_3dm::DatastreamControl::Response",
1148 FUNCTION_SELECTOR_PARAM,
1151 "The descriptor set of the stream to control. When function is SAVE, LOAD, or DEFAULT, can be ALL_STREAMS(0) to apply to all descriptor sets.\nOn Generation 5 products, this must be one of the above legacy constants.",
1154 {
true,
true,
true,
true,
true,
true},
1160 "True or false to enable or disable the stream.",
1163 {
true,
false,
false,
false,
false},
1170 "commands_3dm::DatastreamControl",
1171 "datastream_control",
1172 "Enable/disable the selected data stream.\n\nEach data stream (descriptor set) can be enabled or disabled.\nThe default for the device is all streams enabled.\nFor all functions except 0x01 (use new setting),\nthe new enable flag value is ignored and can be omitted.",
1175 {
true,
true,
true,
true,
true},
1182 struct MetadataFor<commands_3dm::ConstellationSettings::ConstellationId>
1187 { uint32_t(0),
"GPS",
"GPS (G1-G32)" },
1188 { uint32_t(1),
"SBAS",
"SBAS (S120-S158)" },
1189 { uint32_t(2),
"GALILEO",
"GALILEO (E1-E36)" },
1190 { uint32_t(3),
"BeiDou",
"BeiDou (B1-B37)" },
1191 { uint32_t(5),
"QZSS",
"QZSS (Q1-Q5)" },
1192 { uint32_t(6),
"GLONASS",
"GLONASS (R1-R32)" },
1210 { uint32_t(1),
"L1SAIF",
"Available only for QZSS" },
1239 "Enable/Disable constellation",
1247 "reserved_channels",
1248 "Minimum number of channels reserved for this constellation",
1257 "Maximum number of channels to use for this constallation",
1266 "Constellation option Flags",
1290 "max_channels_available",
1291 "Maximum channels available",
1294 {
true,
false,
false,
false,
false},
1300 "Maximum channels to use",
1303 {
true,
false,
false,
false,
false},
1309 "Number of constellation configurations",
1312 {
true,
false,
false,
false,
false},
1318 "Constellation Settings",
1321 {
true,
false,
false,
false,
false},
1328 "commands_3dm::ConstellationSettings::Response",
1345 FUNCTION_SELECTOR_PARAM,
1351 {
true,
false,
false,
false,
false},
1360 {
true,
false,
false,
false,
false},
1369 {
true,
false,
false,
false,
false},
1376 "commands_3dm::ConstellationSettings",
1377 "constellation_settings",
1378 "This command configures which satellite constellations are enabled and how many channels are dedicated to tracking each constellation.\n\nMaximum number of tracking channels to use (total for all constellations):\n0 to max_channels_available (from reply message)\n\nFor each constellation you wish to use, include a ConstellationSettings struct. Note the following:\n\nTotal number of tracking channels (sum of 'reserved_channels' for all constellations) must be <= 32:\n0 -> 32 Number of reserved channels\n0 -> 32 Max number of channels (>= reserved channels)\n\nThe factory default setting is: GPS and GLONASS enabled. Min/Max for GPS = 8/16, GLONASS = 8/14, SBAS = 1/3, QZSS = 0/3.\n\nWarning: SBAS functionality shall not be used in 'safety of life' applications!\nWarning: Any setting that causes the total reserved channels to exceed 32 will result in a NACK.\nWarning: You cannot enable GLONASS and BeiDou at the same time.\nNote: Enabling SBAS and QZSS augments GPS accuracy.\nNote: It is recommended to disable GLONASS and BeiDou if a GPS-only antenna or GPS-only SAW filter is used.",
1381 {
true,
true,
true,
true,
true},
1393 { uint32_t(1),
"enable_ranging",
"Use SBAS pseudo-ranges in position solution" },
1394 { uint32_t(2),
"enable_corrections",
"Use SBAS differential corrections" },
1395 { uint32_t(4),
"apply_integrity",
"Use SBAS integrity information. If enabled, only GPS satellites for which integrity information is available will be used." },
1415 "0 - SBAS Disabled, 1 - SBAS enabled",
1418 {
true,
false,
false,
false,
false},
1424 "SBAS options, see definition",
1427 {
true,
false,
false,
false,
false},
1432 "num_included_prns",
1433 "Number of SBAS PRNs to include in search (0 = include all)",
1436 {
true,
false,
false,
false,
false},
1442 "List of specific SBAS PRNs to search for",
1445 {
true,
false,
false,
false,
false},
1452 "commands_3dm::GnssSbasSettings::Response",
1469 FUNCTION_SELECTOR_PARAM,
1472 "0 - SBAS Disabled, 1 - SBAS enabled",
1475 {
true,
false,
false,
false,
false},
1481 "SBAS options, see definition",
1484 {
true,
false,
false,
false,
false},
1489 "num_included_prns",
1490 "Number of SBAS PRNs to include in search (0 = include all)",
1493 {
true,
false,
false,
false,
false},
1499 "List of specific SBAS PRNs to search for",
1502 {
true,
false,
false,
false,
false},
1509 "commands_3dm::GnssSbasSettings",
1511 "Configure the SBAS subsystem\n\n\n",
1514 {
true,
true,
true,
true,
true},
1526 { uint32_t(0),
"NONE",
"No assisted fix (default)" },
1527 { uint32_t(1),
"ENABLED",
"Enable assisted fix" },
1531 "AssistedFixOption",
1547 "Assisted fix options",
1550 {
true,
false,
false,
false,
false},
1556 "Assisted fix flags (set to 0xFF)",
1559 {
true,
false,
false,
false,
false},
1566 "commands_3dm::GnssAssistedFix::Response",
1583 FUNCTION_SELECTOR_PARAM,
1586 "Assisted fix options",
1589 {
true,
false,
false,
false,
false},
1595 "Assisted fix flags (set to 0xFF)",
1598 {
true,
false,
false,
false,
false},
1605 "commands_3dm::GnssAssistedFix",
1606 "GNSS Assisted Fix Settings",
1607 "Set the options for assisted GNSS fix.\n\nDevices that implement this command have a dedicated GNSS flash memory and a non-volatile FRAM.\nThese storage mechanisms are used to retain information about the last good GNSS fix. This can greatly reduces the TTFF (Time To First Fix) depending on the age of the stored information.\nThe TTFF can be as low as one second, or up to the equivalent of a cold start. There is a small increase in power used when enabling assisted fix.\n\nThe fastest fix will be obtained by supplying the device with a GNSS Assist Time Update message containing the current GPS time immediately after subsequent power up.\nThis allows the device to determine if the last GNSS information saved is still fresh enough to improve the TTFF.\n\nNOTE: Non-volatile GNSS memory is cleared when going from an enabled state to a disabled state.\nWARNING: The clearing operation results in an erase operation on the GNSS Flash. The flash has a limited durability of 100,000 write/erase cycles",
1610 {
true,
true,
true,
true,
true},
1624 "GPS Time of week [seconds]",
1627 {
true,
false,
false,
false,
false},
1633 "GPS Weeks since 1980 [weeks]",
1636 {
true,
false,
false,
false,
false},
1642 "Accuracy of time information [seconds]",
1645 {
true,
false,
false,
false,
false},
1652 "commands_3dm::GnssTimeAssistance::Response",
1669 FUNCTION_SELECTOR_PARAM,
1672 "GPS Time of week [seconds]",
1675 {
true,
false,
false,
false,
false},
1681 "GPS Weeks since 1980 [weeks]",
1684 {
true,
false,
false,
false,
false},
1690 "Accuracy of time information [seconds]",
1693 {
true,
false,
false,
false,
false},
1700 "commands_3dm::GnssTimeAssistance",
1701 "gnss_time_assistance",
1702 "Provide the GNSS subsystem with initial time information.\n\nThis message is required immediately after power up if GNSS Assist was enabled when the device was powered off.\nThis will initialize the subsystem clock to help reduce the time to first fix (TTFF).",
1705 {
true,
true,
false,
false,
false},
1718 "target_descriptor",
1722 {
true,
false,
false,
false,
false,
true},
1728 "True if the filter is currently enabled.",
1731 {
true,
false,
false,
false,
false},
1737 "True if the filter cutoff was manually configured.",
1740 {
true,
false,
false,
false,
false},
1746 "The cutoff frequency of the filter. If the filter is in\nauto mode, this value is unspecified.",
1749 {
true,
false,
false,
false,
false},
1755 "Reserved and must be ignored.",
1758 {
true,
false,
false,
false,
false},
1765 "commands_3dm::ImuLowpassFilter::Response",
1782 FUNCTION_SELECTOR_PARAM,
1784 "target_descriptor",
1785 "Field descriptor of filtered quantity within the Sensor data set.\nSupported values are accel (0x04), gyro (0x05), mag (0x06), and\npressure (0x17), provided the data is supported by the device.\nExcept with the READ function selector, this can be 0 to apply to all of the above quantities.",
1788 {
true,
true,
true,
true,
true,
true},
1794 "The target data will be filtered if this is true.",
1797 {
true,
false,
false,
false,
false},
1803 "If false, the cutoff frequency is set to half of the\nstreaming rate as configured by the message format command.\nOtherwise, the cutoff frequency is set according to the\nfollowing 'frequency' parameter.",
1806 {
true,
false,
false,
false,
false},
1812 "-3dB cutoff frequency in Hz. Will not affect filtering if 'manual' is false.",
1815 {
true,
false,
false,
false,
false},
1821 "Reserved, set to 0x00.",
1824 {
true,
false,
false,
false,
false},
1831 "commands_3dm::ImuLowpassFilter",
1832 "Advanced Low-Pass Filter Settings",
1833 "Advanced configuration for the IMU data quantity low-pass filters.\n\nDeprecated, use the lowpass filter (0x0C,0x54) command instead.\n\nThe scaled data quantities are by default filtered through a single-pole IIR low-pass filter\nwhich is configured with a -3dB cutoff frequency of half the reporting frequency (set by\ndecimation factor in the IMU Message Format command) to prevent aliasing on a per data\nquantity basis. This advanced configuration command allows for the cutoff frequency to\nbe configured independently of the data reporting frequency as well as allowing for a\ncomplete bypass of the digital low-pass filter.\n\nPossible data descriptors:\n0x04 - Scaled accelerometer data\n0x05 - Scaled gyro data\n0x06 - Scaled magnetometer data (if applicable)\n0x17 - Scaled pressure data (if applicable)",
1836 {
true,
true,
true,
true,
true},
1848 { uint32_t(0),
"DISABLED",
"PPS output is disabled. Not valid for PPS source command." },
1849 { uint32_t(1),
"RECEIVER_1",
"PPS is provided by GNSS receiver 1." },
1850 { uint32_t(2),
"RECEIVER_2",
"PPS is provided by GNSS receiver 2." },
1851 { uint32_t(3),
"GPIO",
"PPS is provided to an external GPIO pin. Use the GPIO Setup command to choose and configure the pin." },
1852 { uint32_t(4),
"GENERATED",
"PPS is generated from the system oscillator." },
1875 {
true,
false,
false,
false,
false},
1882 "commands_3dm::PpsSource::Response",
1899 FUNCTION_SELECTOR_PARAM,
1905 {
true,
false,
false,
false,
false},
1912 "commands_3dm::PpsSource",
1914 "Controls the Pulse Per Second (PPS) source.",
1917 {
true,
true,
true,
true,
true},
1929 { uint32_t(0),
"UNUSED",
"The pin is not used. It may be technically possible to read the pin state in this mode, but this is not guaranteed to be true of all devices or pins." },
1930 { uint32_t(1),
"GPIO",
"General purpose input or output. Use this for direct control of pin output state or to stream the state of the pin." },
1931 { uint32_t(2),
"PPS",
"Pulse per second input or output." },
1932 { uint32_t(3),
"ENCODER",
"Motor encoder/odometer input." },
1933 { uint32_t(4),
"TIMESTAMP",
"Precision Timestamping. Use with Event Trigger Configuration (0x0C,0x2E)." },
1934 { uint32_t(5),
"UART",
"UART data or control lines." },
1952 { uint32_t(0),
"UNUSED",
"Use 0 unless otherwise specified." },
1953 { uint32_t(1),
"GPIO_INPUT",
"Pin will be an input. This can be used to stream or poll the value and is the default setting." },
1954 { uint32_t(2),
"GPIO_OUTPUT_LOW",
"Pin is an output initially in the LOW state. This state will be restored during system startup if the configuration is saved." },
1955 { uint32_t(3),
"GPIO_OUTPUT_HIGH",
"Pin is an output initially in the HIGH state. This state will be restored during system startup if the configuration is saved." },
1956 { uint32_t(1),
"PPS_INPUT",
"Pin will receive the pulse-per-second signal. Only one pin can have this behavior. This will only work if the PPS Source command is configured to GPIO." },
1957 { uint32_t(2),
"PPS_OUTPUT",
"Pin will transmit the pulse-per-second signal from the device." },
1958 { uint32_t(1),
"ENCODER_A",
"Encoder 'A' quadrature input. Only one pin can have this behavior. The last command to set this behavior will take precedence." },
1959 { uint32_t(2),
"ENCODER_B",
"Encoder 'B' quadrature input. Only one pin can have this behavior. The last command to set this behavior will take precedence." },
1960 { uint32_t(1),
"TIMESTAMP_RISING",
"Rising edges will be timestamped." },
1961 { uint32_t(2),
"TIMESTAMP_FALLING",
"Falling edges will be timestamped." },
1962 { uint32_t(3),
"TIMESTAMP_EITHER",
"Both rising and falling edges will be timestamped." },
1963 { uint32_t(33),
"UART_PORT2_TX",
"(0x21) UART port 2 transmit." },
1964 { uint32_t(34),
"UART_PORT2_RX",
"(0x22) UART port 2 receive." },
1965 { uint32_t(49),
"UART_PORT3_TX",
"(0x31) UART port 3 transmit." },
1966 { uint32_t(50),
"UART_PORT3_RX",
"(0x32) UART port 3 receive." },
1984 { uint32_t(1),
"open_drain",
"The pin will be an open-drain output. The state will be either LOW or FLOATING instead of LOW or HIGH, respectively. This is used to connect multiple open-drain outputs from several devices. An internal or external pull-up resistor is typically used in combination. The maximum voltage of an open drain output is subject to the device maximum input voltage range found in the specifications." },
1985 { uint32_t(2),
"pulldown",
"The pin will have an internal pull-down resistor enabled. This is useful for connecting inputs to signals which can only be pulled high such as mechanical switches. Cannot be used in combination with pull-up. See the device specifications for the resistance value." },
1986 { uint32_t(4),
"pullup",
"The pin will have an internal pull-up resistor enabled. Useful for connecting inputs to signals which can only be pulled low such as mechanical switches, or in combination with an open drain output. Cannot be used in combination with pull-down. See the device specifications for the resistance value. Use of this mode may restrict the maximum allowed input voltage. See the device datasheet for details." },
2006 "GPIO pin number counting from 1. For save, load, and default function selectors, this can be 0 to select all pins.",
2009 {
true,
true,
true,
true,
true,
true},
2015 "Determines how the pin will be used.",
2018 {
true,
false,
false,
false,
false},
2024 "Select an appropriate value from the enumeration based on the selected feature (e.g. for PPS, select one of the values prefixed with PPS_.)",
2027 {
true,
false,
false,
false,
false},
2033 "GPIO configuration. May be restricted depending on device, pin, feature, and behavior. See device user manual.",
2036 {
true,
false,
false,
false,
false},
2043 "commands_3dm::GpioConfig::Response",
2060 FUNCTION_SELECTOR_PARAM,
2063 "GPIO pin number counting from 1. For save, load, and default function selectors, this can be 0 to select all pins.",
2066 {
true,
true,
true,
true,
true,
true},
2072 "Determines how the pin will be used.",
2075 {
true,
false,
false,
false,
false},
2081 "Select an appropriate value from the enumeration based on the selected feature (e.g. for PPS, select one of the values prefixed with PPS_.)",
2084 {
true,
false,
false,
false,
false},
2090 "GPIO configuration. May be restricted depending on device, pin, feature, and behavior. See device user manual.",
2093 {
true,
false,
false,
false,
false},
2100 "commands_3dm::GpioConfig",
2101 "GPIO Configuration",
2102 "Configures the user GPIO pins on the connector for use with several built-in functions or for general input or output.\n\nGPIO pins are device-dependent. Some features are only available on\ncertain pins. Some behaviors require specific configurations.\nConsult the device user manual for restrictions and default settings.\n\nTo avoid glitches on GPIOs configured as an output in a mode other than\nGPIO, always configure the relevant function before setting up the pin\nwith this command. Otherwise, the pin state will be undefined between\nthis command and the one to set up the feature. For input pins, use\nthis command first so the state is well-defined when the feature is\ninitialized.\n\nSome configurations can only be active on one pin at a time. If such\nconfiguration is applied to a second pin, the second one will take\nprecedence and the original pin's configuration will be reset.\n",
2105 {
true,
true,
true,
true,
true},
2119 "GPIO pin number counting from 1. Cannot be 0.",
2122 {
true,
true,
false,
false,
false,
true},
2131 {
true,
false,
false,
false,
false},
2138 "commands_3dm::GpioState::Response",
2155 FUNCTION_SELECTOR_PARAM,
2158 "GPIO pin number counting from 1. Cannot be 0.",
2161 {
true,
true,
false,
false,
false,
true},
2170 {
true,
false,
false,
false,
false},
2177 "commands_3dm::GpioState",
2179 "Allows the state of the pin to be read or controlled.\n\nThis command serves two purposes: 1) To allow reading the state of a pin via command,\nrather than polling a data quantity, and 2) to provide a way to set the output state\nwithout also having to specify the operating mode.\n\nThe state read back from the pin is the physical state of the pin, rather than a\nconfiguration value. The state can be read regardless of its configuration as long as\nthe device supports GPIO input on that pin. If the pin is set to an output, the read\nvalue would match the output value.\n\nWhile the state of a pin can always be set, it will only have an observable effect if\nthe pin is set to output mode.\n\nThis command does not support saving, loading, or resetting the state. Instead, use the\nGPIO Configuration command, which allows the initial state to be configured.",
2182 {
true,
true,
false,
false,
false},
2194 { uint32_t(0),
"DISABLED",
"Encoder is disabled." },
2195 { uint32_t(2),
"QUADRATURE",
"Quadrature encoder mode." },
2218 {
true,
false,
false,
false,
false},
2224 "Encoder pulses per meter of distance traveled [pulses/m].\nDistance traveled is computed using the formula d = p / N * 2R * pi, where d is distance,\np is the number of pulses received, N is the encoder resolution, and R is the wheel radius.\nBy simplifying all of the parameters into one, the formula d = p / S is obtained, where s\nis the odometer scaling factor passed to this command. S is equivalent to N / (2R * pi) and\nhas units of pulses / meter. N is in units of 'A' pulses per revolution and R is in meters.\nMake this value negative if the odometer is mounted so that it rotates backwards.",
2227 {
true,
false,
false,
false,
false},
2233 "Uncertainty in encoder counts to distance translation (1-sigma value) [m/m].",
2236 {
true,
false,
false,
false,
false},
2243 "commands_3dm::Odometer::Response",
2260 FUNCTION_SELECTOR_PARAM,
2266 {
true,
false,
false,
false,
false},
2272 "Encoder pulses per meter of distance traveled [pulses/m].\nDistance traveled is computed using the formula d = p / N * 2R * pi, where d is distance,\np is the number of pulses received, N is the encoder resolution, and R is the wheel radius.\nBy simplifying all of the parameters into one, the formula d = p / S is obtained, where s\nis the odometer scaling factor passed to this command. S is equivalent to N / (2R * pi) and\nhas units of pulses / meter. N is in units of 'A' pulses per revolution and R is in meters.\nMake this value negative if the odometer is mounted so that it rotates backwards.",
2275 {
true,
false,
false,
false,
false},
2281 "Uncertainty in encoder counts to distance translation (1-sigma value) [m/m].",
2284 {
true,
false,
false,
false,
false},
2291 "commands_3dm::Odometer",
2292 "Odometer Settings",
2293 "Configures the hardware odometer interface.\n",
2296 {
true,
true,
true,
true,
true},
2308 { uint32_t(1),
"TRIGGER_TYPES",
"Query the supported trigger types and max count for each." },
2309 { uint32_t(2),
"ACTION_TYPES",
"Query the supported action types and max count for each." },
2329 "Trigger or action type, as defined in the respective setup command.",
2338 "This is the maximum number of instances supported for this type.",
2363 "Query type specified in the command.",
2366 {
true,
false,
false,
false,
false,
true},
2372 "Number of slots available. The 'instance' number for\nthe configuration or control commands must be between 1 and this value.",
2375 {
true,
false,
false,
false,
false},
2381 "Number of supported types.",
2384 {
true,
false,
false,
false,
false},
2390 "List of supported types.",
2393 {
true,
false,
false,
false,
false},
2400 "commands_3dm::GetEventSupport::Response",
2419 "What type of information to retrieve.",
2422 {
true,
false,
false,
false,
false,
true},
2429 "commands_3dm::GetEventSupport",
2430 "Get Supported Events",
2431 "Lists the available trigger or action types.\n\nThere are a limited number of trigger and action slots available\nin the device. Up to M triggers and N actions can be configured at once\nin slots 1..M and 1..N respectively. M and N are identified by the\nmax_instances field in the response with the appropriate query selector.\n\nEach slot can be configured as one of a variety of different types of\ntriggers or actions. The supported types are enumerated in the response\nto this command. Additionally, there is a limit on the number of a given\ntype. In other words, while the device may support M triggers in total,\nonly a few of them maybe usable as a given type. This limit helps optimize\ndevice resources. The limit is identified in the count field.\n\nAll of the information in this command is available in the user manual.\nThis command provides a programmatic method for obtaining the information.\n",
2446 { uint32_t(0),
"DISABLED",
"Trigger is disabled." },
2447 { uint32_t(1),
"ENABLED",
"Trigger is enabled and will work normally." },
2448 { uint32_t(2),
"TEST",
"Forces the trigger to the active state for testing purposes." },
2449 { uint32_t(3),
"TEST_PULSE",
"Trigger is forced to the active state for one event cycle only. After the test cycle, the mode reverts to the previous state (either enabled or disabled)." },
2469 "Trigger instance to affect. 0 can be used to apply the mode to all\nconfigured triggers, except when the function selector is READ.",
2472 {
true,
true,
true,
true,
true,
true},
2478 "How to change the trigger state. Except when instance is 0, the\ncorresponding trigger must be configured, i.e. not have type 0.",
2481 {
true,
false,
false,
false,
false},
2488 "commands_3dm::EventControl::Response",
2505 FUNCTION_SELECTOR_PARAM,
2508 "Trigger instance to affect. 0 can be used to apply the mode to all\nconfigured triggers, except when the function selector is READ.",
2511 {
true,
true,
true,
true,
true,
true},
2517 "How to change the trigger state. Except when instance is 0, the\ncorresponding trigger must be configured, i.e. not have type 0.",
2520 {
true,
false,
false,
false,
false},
2527 "commands_3dm::EventControl",
2529 "Enables or disables event triggers.\n\nTriggers can be disabled, enabled, and tested. While disabled, a trigger will\nnot evaluate its logic and effective behave like no trigger is configured.\nA disabled trigger will not activate any actions. Triggers are disabled by default.\n\nUse this command to enable (or disable) a trigger, or to place it into a test mode.\nWhen in test mode, the trigger logic is disabled but the output is forced to\nthe active state, meaning that it will behave as if the trigger logic is satisfied\nand any associated actions will execute.",
2532 {
true,
true,
true,
true,
true},
2544 { uint32_t(1),
"active",
"True if the trigger is currently active (either due to its logic or being in test mode)." },
2545 { uint32_t(2),
"enabled",
"True if the trigger is enabled." },
2546 { uint32_t(4),
"test",
"True if the trigger is in test mode." },
2566 "Configured trigger type.",
2600 "Number of entries requested. If requested_count was 0, this is the number of supported trigger slots.",
2603 {
true,
false,
false,
false,
false},
2609 "A list of the configured triggers. Entries are in the order requested, or in increasing order if count was 0.",
2612 {
true,
false,
false,
false,
false},
2619 "commands_3dm::GetEventTriggerStatus::Response",
2638 "Number of entries requested. If 0, requests all trigger slots.",
2641 {
true,
false,
false,
false,
false},
2646 "requested_instances",
2647 "List of trigger instances to query.",
2650 {
true,
false,
false,
false,
false},
2657 "commands_3dm::GetEventTriggerStatus",
2658 "Get Trigger Status",
2676 "Configured action type.",
2685 "Associated trigger instance.",
2710 "Number of entries requested. If requested_count was 0, this is the number of supported action slots.",
2713 {
true,
false,
false,
false,
false},
2719 "A list of the configured actions. Entries are in the order requested, or in increasing order if count was 0.",
2722 {
true,
false,
false,
false,
false},
2729 "commands_3dm::GetEventActionStatus::Response",
2748 "Number of entries requested. If 0, requests all action slots.",
2751 {
true,
false,
false,
false,
false},
2756 "requested_instances",
2757 "List of action instances to query.",
2760 {
true,
false,
false,
false,
false},
2767 "commands_3dm::GetEventActionStatus",
2768 "Get Action Status",
2784 { uint32_t(0),
"DISABLED",
"The pin will have no effect and the trigger will never activate." },
2785 { uint32_t(1),
"WHILE_HIGH",
"The trigger will be active while the pin is high." },
2786 { uint32_t(2),
"WHILE_LOW",
"The trigger will be active while the pin is low." },
2787 { uint32_t(4),
"EDGE",
"Use if the pin is configured for timestamping via the 3DM Gpio Configuration command (0x0C41)." },
2816 "How the pin state affects the trigger.",
2839 { uint32_t(1),
"WINDOW",
"Window comparison. Trigger is active if low_thres <= value <= high_thres. If the thresholds are reversed, the trigger is active when value < high_thres or value > low_thres." },
2840 { uint32_t(2),
"INTERVAL",
"Trigger at evenly-spaced intervals. Normally used with time fields to trigger periodically. Trigger is active when (value % interval) <= int_thres. If the thresholds are reversed (high_thres < low_thres) then the trigger is active when (value % low_thres) > high_thres." },
2860 "Descriptor set of target data quantity.",
2869 "Field descriptor of target data quantity.",
2878 "1-based index of the target parameter within the MIP field. E.g. for Scaled Accel (0x80,0x04) a value of 2 would represent the Y axis.",
2887 "Determines the type of comparison.",
2935 "Comparison of a supported MIP field parameter against a set of thresholds.\n\nTriggers when a data quantity meets the comparison criteria. The comparison can be either\na window comparison with high and low thresholds or a periodic interval.\n\nThe data quantity is identified by the MIP descriptor set, field descriptor, and parameter number.\nE.g. Scaled acceleration in the Z direction is specified with desc_set=0x80 (sensor data),\nfield_desc=0x04 (scaled accel), and param_id=3 (the third parameter and Z axis).\n\nThe window comparison can be used for a variety of purposes, such as disabling\na robot's drive motors if it tips over. In this case, a window comparison could\nbe set up to monitor the roll angle, (0x80,0x0C,3). The lower threshold would be set\nto -pi/2 radians and the upper threshold to pi/2 radians.\n\nThe interval trigger can be used to perform an action periodically if used with\na time field. E.g. to execute the action every 16 ms, set an interval comparison on\nthe GPS time of week parameter (0x80,0xD3,1) with high_thres set to 0.016. The lower\nthreshold determines how long the trigger is active within the 16-ms period.\n\nEither comparison type can be inverted by reversing the threshold values; setting\nlow_thres > high_thres will result in the reverse condition.\n",
2948 "The last column of a truth table describing the output given the state of each input.",
2957 "List of trigger IDs for inputs. Use 0 for unused inputs.",
2967 "CombinationParams",
2968 "Combinationparams",
2980 { uint32_t(0),
"NONE",
"No trigger selected. The state will always be inactive." },
2981 { uint32_t(1),
"GPIO",
"Trigger based on the state of a GPIO pin. See GpioParams." },
2982 { uint32_t(2),
"THRESHOLD",
"Compare a data quantity against a high and low threshold. See ThresholdParams." },
2983 { uint32_t(3),
"COMBINATION",
"Logical combination of two or more triggers. See CombinationParams." },
3046 "Trigger number. When function is SAVE, LOAD, or DEFAULT, this can be 0 to apply to all instances.",
3049 {
true,
true,
true,
true,
true,
true},
3055 "Type of trigger to configure.",
3058 {
true,
false,
false,
false,
false},
3067 {
true,
false,
false,
false,
false},
3074 "commands_3dm::EventTrigger::Response",
3091 FUNCTION_SELECTOR_PARAM,
3094 "Trigger number. When function is SAVE, LOAD, or DEFAULT, this can be 0 to apply to all instances.",
3097 {
true,
true,
true,
true,
true,
true},
3103 "Type of trigger to configure.",
3106 {
true,
false,
false,
false,
false},
3115 {
true,
false,
false,
false,
false},
3122 "commands_3dm::EventTrigger",
3123 "Event Trigger Configuration",
3124 "Configures various types of event triggers.",
3127 {
true,
true,
true,
true,
true},
3139 { uint32_t(0),
"DISABLED",
"Pin state will not be changed." },
3140 { uint32_t(1),
"ACTIVE_HIGH",
"Pin will be set high when the trigger is active and low otherwise." },
3141 { uint32_t(2),
"ACTIVE_LOW",
"Pin will be set low when the trigger is active and high otherwise." },
3142 { uint32_t(5),
"ONESHOT_HIGH",
"Pin will be set high each time the trigger activates. It will not be set low." },
3143 { uint32_t(6),
"ONESHOT_LOW",
"Pin will be set low each time the trigger activates. It will not be set high." },
3144 { uint32_t(7),
"TOGGLE",
"Pin will change to the opposite state each time the trigger activates." },
3173 "Behavior of the pin.",
3198 "MIP data descriptor set.",
3207 "Decimation from the base rate.\nIf 0, a packet is emitted each time the trigger activates.\nOtherwise, packets will be streamed while the trigger is active.\nThe internal decimation counter is reset if the trigger deactivates.",
3216 "Number of mip fields in the packet. Limited to 12.",
3225 "List of field descriptors.",
3248 { uint32_t(0),
"NONE",
"No action. Parameters should be empty." },
3249 { uint32_t(1),
"GPIO",
"Control the state of a GPIO pin. See GpioParameters." },
3250 { uint32_t(2),
"MESSAGE",
"Output a data packet. See MessageParameters." },
3270 "Gpio parameters, if type == GPIO. Ignore otherwise.",
3279 "Message parameters, if type == MESSAGE. Ignore otherwise.",
3304 "Action number. When function is SAVE, LOAD, or DEFAULT, this can be 0 to apply to all instances.",
3307 {
true,
true,
true,
true,
true,
true},
3313 "Trigger ID number.",
3316 {
true,
false,
false,
false,
false},
3322 "Type of action to configure.",
3325 {
true,
false,
false,
false,
false},
3334 {
true,
false,
false,
false,
false},
3341 "commands_3dm::EventAction::Response",
3358 FUNCTION_SELECTOR_PARAM,
3361 "Action number. When function is SAVE, LOAD, or DEFAULT, this can be 0 to apply to all instances.",
3364 {
true,
true,
true,
true,
true,
true},
3370 "Trigger ID number.",
3373 {
true,
false,
false,
false,
false},
3379 "Type of action to configure.",
3382 {
true,
false,
false,
false,
false},
3391 {
true,
false,
false,
false,
false},
3398 "commands_3dm::EventAction",
3399 "Event Action Configuration",
3400 "Configures various types of event actions.",
3403 {
true,
true,
true,
true,
true},
3417 "accelerometer bias in the sensor frame (x,y,z) [g]",
3420 {
true,
false,
false,
false,
false},
3427 "commands_3dm::AccelBias::Response",
3444 FUNCTION_SELECTOR_PARAM,
3447 "accelerometer bias in the sensor frame (x,y,z) [g]",
3450 {
true,
false,
false,
false,
false},
3457 "commands_3dm::AccelBias",
3458 "Configure Accel Bias",
3459 "Configures the user specified accelerometer bias\n\nThe user specified bias is subtracted from the calibrated accelerometer output. Value is input in the sensor frame.",
3462 {
true,
true,
true,
true,
true},
3476 "gyro bias in the sensor frame (x,y,z) [radians/second]",
3479 {
true,
false,
false,
false,
false},
3486 "commands_3dm::GyroBias::Response",
3503 FUNCTION_SELECTOR_PARAM,
3506 "gyro bias in the sensor frame (x,y,z) [radians/second]",
3509 {
true,
false,
false,
false,
false},
3516 "commands_3dm::GyroBias",
3517 "Configure Gyro Bias",
3518 "Configures the user specified gyroscope bias\n\nThe user specified bias is subtracted from the calibrated angular rate output. Value is input in the sensor frame.",
3521 {
true,
true,
true,
true,
true},
3535 "gyro bias in the sensor frame (x,y,z) [radians/second]",
3538 {
true,
false,
false,
false,
false},
3545 "commands_3dm::CaptureGyroBias::Response",
3563 "averaging_time_ms",
3564 "Averaging time [milliseconds]",
3567 {
true,
false,
false,
false,
false},
3574 "commands_3dm::CaptureGyroBias",
3575 "Capture Gyro Bias",
3576 "Samples gyro for a specified time range and writes the averaged result to the Gyro Bias vector in RAM\n\nThe device will average the gyro output for the duration of 'averaging_time_ms.' To store the resulting vector\nin non-volatile memory, use the Set Gyro Bias command.\nIMPORTANT: The device must be stationary and experiencing minimum vibration for the duration of 'averaging_time_ms'\nAveraging Time range: 1000 to 30,000",
3593 "hard iron offset in the sensor frame (x,y,z) [Gauss]",
3596 {
true,
false,
false,
false,
false},
3603 "commands_3dm::MagHardIronOffset::Response",
3620 FUNCTION_SELECTOR_PARAM,
3623 "hard iron offset in the sensor frame (x,y,z) [Gauss]",
3626 {
true,
false,
false,
false,
false},
3633 "commands_3dm::MagHardIronOffset",
3634 "Magnetometer Hard Iron Offset",
3635 "Configure the user specified magnetometer hard iron offset vector\n\nThe values for this offset are determined empirically by external software algorithms\nbased on calibration data taken after the device is installed in its application. These values\ncan be obtained and set by using Microstrain software tools.\nAlternatively, on some systems, the auto-mag calibration feature may be used to capture these values in-run.\nThe offset is applied to the scaled magnetometer vector prior to output.",
3638 {
true,
true,
true,
true,
true},
3652 "soft iron matrix [dimensionless]",
3655 {
true,
false,
false,
false,
false},
3662 "commands_3dm::MagSoftIronMatrix::Response",
3679 FUNCTION_SELECTOR_PARAM,
3682 "soft iron matrix [dimensionless]",
3685 {
true,
false,
false,
false,
false},
3692 "commands_3dm::MagSoftIronMatrix",
3693 "Magnetometer Soft Iron Matrix",
3694 "Configure the user specified magnetometer soft iron offset matrix\n\nThe values for this matrix are determined empirically by external software algorithms\nbased on calibration data taken after the device is installed in its application. These values\ncan be obtained and set by using Microstrain software tools.\nAlternatively, on some systems, the auto-mag calibration feature may be used to capture these values in-run.\nThe matrix is applied to the scaled magnetometer vector prior to output.\n\nThe matrix is in row major order:\nEQSTART M = \\begin{bmatrix} 0 & 1 & 2 \\\\ 3 & 4 & 5 \\\\ 6 & 7 & 8 \\end{bmatrix} EQEND\n",
3697 {
true,
true,
true,
true,
true},
3711 "If true, coning and sculling compensation is enabled.",
3714 {
true,
false,
false,
false,
false},
3721 "commands_3dm::ConingScullingEnable::Response",
3738 FUNCTION_SELECTOR_PARAM,
3741 "If true, coning and sculling compensation is enabled.",
3744 {
true,
false,
false,
false,
false},
3751 "commands_3dm::ConingScullingEnable",
3752 "Coning and Sculling Enable",
3753 "Controls the Coning and Sculling Compenstation setting.",
3756 {
true,
true,
true,
true,
true},
3763 struct MetadataFor<commands_3dm::Sensor2VehicleTransformEuler::Response>
3773 {
true,
false,
false,
false,
false},
3782 {
true,
false,
false,
false,
false},
3791 {
true,
false,
false,
false,
false},
3798 "commands_3dm::Sensor2VehicleTransformEuler::Response",
3815 FUNCTION_SELECTOR_PARAM,
3821 {
true,
false,
false,
false,
false},
3830 {
true,
false,
false,
false,
false},
3839 {
true,
false,
false,
false,
false},
3846 "commands_3dm::Sensor2VehicleTransformEuler",
3847 "Sensor to Vehicle Frame Transformation Euler",
3848 "Sets the sensor-to-vehicle frame transformation using Yaw, Pitch, Roll Euler angles.\nThese are the Yaw, Pitch, and Roll mounting angles of the sensor with respect to vehicle frame of reference,\nand describe the transformation of vectors from the sensor body frame to the vehicle frame.<br/>\nNote: This is the transformation, the inverse of the rotation defined in our legacy products.<br/>\nThe transformation may be stored in the device as a matrix or quaternion. When Euler angles are read back from the device, they may not\nbe exactly equal to the Euler angles used to set the transformation, but they are functionally equivalent, such that they result in the same transformation.<br/>\n<br/><br/>\nThis transformation to the vehicle frame will be applied to the following output quantities:<br/><br/>\nIMU:<br/>\nScaled Acceleration<br/>\nScaled Gyro<br/>\nScaled Magnetometer<br/>\nDelta Theta<br/>\nDelta Velocity<br/>\nComplementary Filter Orientation<br/>\n<br/><br/>\nEstimation Filter:<br/>\nEstimated Orientation, Quaternion<br/>\nEstimated Orientation, Matrix<br/>\nEstimated Orientation, Euler Angles<br/>\nEstimated Linear Acceleration<br/>\nEstimated Angular Rate<br/>\nEstimated Gravity Vector<br/>\n<br/>\nChanging this setting will force all low-pass filters, the complementary filter, and the estimation filter to reset.",
3851 {
true,
true,
true,
true,
true},
3858 struct MetadataFor<commands_3dm::Sensor2VehicleTransformQuaternion::Response>
3865 "Unit length quaternion representing transform [w, i, j, k]",
3868 {
true,
false,
false,
false,
false},
3875 "commands_3dm::Sensor2VehicleTransformQuaternion::Response",
3892 FUNCTION_SELECTOR_PARAM,
3895 "Unit length quaternion representing transform [w, i, j, k]",
3898 {
true,
false,
false,
false,
false},
3905 "commands_3dm::Sensor2VehicleTransformQuaternion",
3906 "Sensor to Vehicle Frame Transformation Quaternion",
3907 "Set the sensor to vehicle frame transformation using unit length quaternion.\n\nNote: This is the transformation, the inverse of the rotation.\n\nThis quaternion describes the transformation of vectors from the sensor body frame to the vehicle frame of reference, and satisfies the following relationship:<br/>\n\nEQSTART p^{veh} = q^{-1} p^{sen} q EQEND<br/>\n\nWhere:<br/>\nEQSTART q = (q_w, q_x, q_y, q_z) EQEND is the quaternion describing the transformation. <br/>\nEQSTART p^{sen} = (0, v^{sen}_x, v^{sen}_y, v^{sen}_z) EQEND and EQSTART v^{sen} EQEND is a 3-element vector expressed in the sensor body frame.<br/>\nEQSTART p^{veh} = (0, v^{veh}_x, v^{veh}_y, v^{veh}_z) EQEND and EQSTART v^{veh} EQEND is a 3-element vector expressed in the vehicle frame.<br/>\n\nThe transformation may be stored in the device as a matrix or a quaternion. When the quaternion is read back from the device, it may not\nbe exactly equal to the quaternion used to set the transformation, but it is functionally equivalent.<br/>\n<br/><br/>\nThis transformation affects the following output quantities:<br/><br/>\nIMU:<br/>\nScaled Acceleration<br/>\nScaled Gyro<br/>\nScaled Magnetometer<br/>\nDelta Theta<br/>\nDelta Velocity<br/>\n<br/><br/>\nEstimation Filter:<br/>\nEstimated Orientation, Quaternion<br/>\nEstimated Orientation, Matrix<br/>\nEstimated Orientation, Euler Angles<br/>\nEstimated Linear Acceleration<br/>\nEstimated Angular Rate<br/>\nEstimated Gravity Vector<br/>\n<br/>\nChanging this setting will force all low-pass filters, the complementary filter, and the estimation filter to reset.",
3910 {
true,
true,
true,
true,
true},
3917 struct MetadataFor<commands_3dm::Sensor2VehicleTransformDcm::Response>
3924 "3 x 3 direction cosine matrix, stored in row-major order",
3927 {
true,
false,
false,
false,
false},
3934 "commands_3dm::Sensor2VehicleTransformDcm::Response",
3951 FUNCTION_SELECTOR_PARAM,
3954 "3 x 3 direction cosine matrix, stored in row-major order",
3957 {
true,
false,
false,
false,
false},
3964 "commands_3dm::Sensor2VehicleTransformDcm",
3965 "Sensor to Vehicle Frame Transformation Direction Cosine Matrix",
3966 "Set the sensor to vehicle frame transformation using a using a 3 x 3 direction cosine matrix EQSTART M_{ned}^{veh} EQEND, stored in row-major order in a 9-element array.\n\nThese angles define the transformation of vectors from the sensor body frame to the fixed vehicle frame, according to:<br/>\nEQSTART v^{veh} = M_{sen}^{veh} v^{sen} EQEND<br/>\n\nWhere:<br/>\n\nEQSTART v^{sen} EQEND is a 3-element vector expressed in the sensor body frame. <br/>\nEQSTART v^{veh} EQEND is the same 3-element vector expressed in the vehicle frame. <br/>\n<br/>\nThe matrix elements are stored is row-major order: EQSTART M_{sen}^{veh} = \\begin{bmatrix} M_{11}, M_{12}, M_{13}, M_{21}, M_{22}, M_{23}, M_{31}, M_{32}, M_{33} \\end{bmatrix} EQEND\nThe transformation may be stored in the device as a matrix or a quaternion. When EQSTART M_{sen}^{veh} EQEND is read back from the device, it may not\nbe exactly equal to array used to set the transformation, but it is functionally equivalent.<br/>\n<br/><br/>\nThis transformation affects the following output quantities:<br/><br/>\nIMU:<br/>\nScaled Acceleration<br/>\nScaled Gyro<br/>\nScaled Magnetometer<br/>\nDelta Theta<br/>\nDelta Velocity<br/>\n<br/><br/>\nEstimation Filter:<br/>\nEstimated Orientation, Quaternion<br/>\nEstimated Orientation, Matrix<br/>\nEstimated Orientation, Euler Angles<br/>\nEstimated Linear Acceleration<br/>\nEstimated Angular Rate<br/>\nEstimated Gravity Vector<br/>\n<br/>\nChanging this setting will force all low-pass filters, the complementary filter, and the estimation filter to reset.",
3969 {
true,
true,
true,
true,
true},
3982 "pitch_roll_enable",
3983 "Enable Pitch/Roll corrections",
3986 {
true,
false,
false,
false,
false},
3992 "Enable Heading corrections (only available on devices with magnetometer)",
3995 {
true,
false,
false,
false,
false},
4000 "pitch_roll_time_constant",
4001 "Time constant associated with the pitch/roll corrections [s]",
4004 {
true,
false,
false,
false,
false},
4009 "heading_time_constant",
4010 "Time constant associated with the heading corrections [s]",
4013 {
true,
false,
false,
false,
false},
4020 "commands_3dm::ComplementaryFilter::Response",
4037 FUNCTION_SELECTOR_PARAM,
4039 "pitch_roll_enable",
4040 "Enable Pitch/Roll corrections",
4043 {
true,
false,
false,
false,
false},
4049 "Enable Heading corrections (only available on devices with magnetometer)",
4052 {
true,
false,
false,
false,
false},
4057 "pitch_roll_time_constant",
4058 "Time constant associated with the pitch/roll corrections [s]",
4061 {
true,
false,
false,
false,
false},
4066 "heading_time_constant",
4067 "Time constant associated with the heading corrections [s]",
4070 {
true,
false,
false,
false,
false},
4077 "commands_3dm::ComplementaryFilter",
4078 "Complementary filter settings",
4079 "Configure the settings for the complementary filter which produces the following (0x80) descriptor set values: attitude matrix (0x80,09), quaternion (0x80,0A), and Euler angle (0x80,0C) outputs.\n\nThe filter can be configured to correct for pitch and roll using the accelerometer (with the assumption that linear acceleration is minimal),\nand to correct for heading using the magnetometer (with the assumption that the local magnetic field is dominated by the Earth's own magnetic field).\nPitch/roll and heading corrections each have their own configurable time constants, with a valid range of 1-1000 seconds. The default time constant is 10 seconds.",
4082 {
true,
true,
true,
true,
true},
4094 { uint32_t(0),
"ALL",
"Only allowed for SAVE, LOAD, and DEFAULT function selectors." },
4095 { uint32_t(1),
"ACCEL",
"Accelerometer. Range is specified in g." },
4096 { uint32_t(2),
"GYRO",
"Gyroscope. Range is specified in degrees/s." },
4097 { uint32_t(3),
"MAG",
"Magnetometer. Range is specified in Gauss." },
4098 { uint32_t(4),
"PRESS",
"Pressure sensor. Range is specified in hPa." },
4118 "Which type of sensor will get the new range value.",
4121 {
true,
true,
true,
true,
true,
true},
4127 "Use the 3DM Get Calibrated Sensor Ranges (0x0C,0x53) command to determine this value.",
4130 {
true,
false,
false,
false,
false},
4137 "commands_3dm::SensorRange::Response",
4154 FUNCTION_SELECTOR_PARAM,
4157 "Which type of sensor will get the new range value.",
4160 {
true,
true,
true,
true,
true,
true},
4166 "Use the 3DM Get Calibrated Sensor Ranges (0x0C,0x53) command to determine this value.",
4169 {
true,
false,
false,
false,
false},
4176 "commands_3dm::SensorRange",
4178 "Changes the IMU sensor gain.\n\nThis allows you to optimize the range to get the best accuracy and performance\nwhile minimizing over-range events.\n\nUse the 3DM Get Calibrated Sensor Ranges (0x0C,0x53) command to determine\nthe appropriate setting value for your application. Using values other than\nthose specified may result in a NACK or inaccurate measurement data.",
4181 {
true,
true,
true,
true,
true},
4195 "The value used in the 3DM Sensor Range command and response.",
4204 "The actual range value. Units depend on the sensor type.",
4229 "The sensor type from the command.",
4232 {
true,
false,
false,
false,
false,
true},
4238 "Number of supported ranges.",
4241 {
true,
false,
false,
false,
false},
4247 "List of possible range settings.",
4250 {
true,
false,
false,
false,
false},
4257 "commands_3dm::CalibratedSensorRanges::Response",
4276 "The sensor to query. Cannot be ALL.",
4279 {
true,
false,
false,
false,
false,
true},
4286 "commands_3dm::CalibratedSensorRanges",
4287 "Get Calibrated Sensor Ranges",
4288 "Returns the supported sensor ranges which may be used with the 3DM Sensor Range (0x0C,0x52) command.\n\nThe response includes an array of (u8, float) pairs which map each allowed setting\nto the corresponding maximum range in physical units. See SensorRangeType for units.",
4305 "Descriptor set of the quantity to be filtered.",
4308 {
true,
true,
true,
true,
true,
true},
4314 "Field descriptor of the quantity to be filtered.",
4317 {
true,
true,
true,
true,
true,
true},
4323 "The filter will be enabled if this is true.",
4326 {
true,
false,
false,
false,
false},
4332 "If false, the frequency parameter is ignored and the filter\nwill track to half of the configured message format frequency.",
4335 {
true,
false,
false,
false,
false},
4341 "Cutoff frequency in Hz. This will return the actual frequency\nwhen read out in automatic mode.",
4344 {
true,
false,
false,
false,
false},
4351 "commands_3dm::LowpassFilter::Response",
4368 FUNCTION_SELECTOR_PARAM,
4371 "Descriptor set of the quantity to be filtered.",
4374 {
true,
true,
true,
true,
true,
true},
4380 "Field descriptor of the quantity to be filtered.",
4383 {
true,
true,
true,
true,
true,
true},
4389 "The filter will be enabled if this is true.",
4392 {
true,
false,
false,
false,
false},
4398 "If false, the frequency parameter is ignored and the filter\nwill track to half of the configured message format frequency.",
4401 {
true,
false,
false,
false,
false},
4407 "Cutoff frequency in Hz. This will return the actual frequency\nwhen read out in automatic mode.",
4410 {
true,
false,
false,
false,
false},
4417 "commands_3dm::LowpassFilter",
4418 "Low-pass anti-aliasing filter",
4419 "This command controls the low-pass anti-aliasing filter supported data quantities.\n\nSee the device user manual for data quantities which support the anti-aliasing filter.\n\nIf set to automatic mode, the frequency will track half of the transmission rate\nof the target descriptor according to the configured message format (0x0C,0x0F).\nFor example, if scaled accel (0x80,0x04) is set to stream at 100 Hz, the filter would\nbe set to 50 Hz. Changing the message format to 200 Hz would automatically adjust the\nfilter to 100 Hz.\n\nFor WRITE, SAVE, LOAD, and DEFAULT function selectors, the descriptor set and/or field descriptor\nmay be 0x00 to set, save, load, or reset the setting for all supported descriptors. The\nfield descriptor must be 0x00 if the descriptor set is 0x00.\n",
4422 {
true,
true,
true,
true,
true},
4429 static constexpr
inline std::initializer_list<const FieldInfo*> COMMANDS_3DM = {
Definition: commands_3dm.hpp:1502
Definition: commands_3dm.hpp:2048
Definition: commands_3dm.hpp:1417
Definition: commands_3dm.hpp:207
Definition: commands_3dm.hpp:3180
Definition: commands_3dm.hpp:1217
Definition: commands_3dm.hpp:4000
Definition: commands_3dm.hpp:1717
Definition: commands_3dm.hpp:1898
Definition: commands_3dm.hpp:3423
Definition: commands_3dm.hpp:1945
Definition: commands_3dm.hpp:2146
SensorRangeType
Definition: commands_3dm.hpp:180
Definition: commands_3dm.hpp:593
Definition: commands_3dm.hpp:2397
Definition: commands_3dm.hpp:1120
Definition: commands_3dm.hpp:1989
Definition: commands_3dm.hpp:864
@ GPIO
Trigger based on the state of a GPIO pin. See GpioParams.
Definition: commands_3dm.hpp:837
Mode
Definition: commands_3dm.hpp:2287
Definition: commands_3dm.hpp:2484
Definition: commands_3dm.hpp:1858
Definition: commands_3dm.hpp:2973
Source
Definition: commands_3dm.hpp:1947
Definition: commands_3dm.hpp:2780
@ THRESHOLD
Compare a data quantity against a high and low threshold. See ThresholdParams.
MessageID
Definition: commands_3dm.hpp:147
Definition: commands_3dm.hpp:1619
Definition: commands_3dm.hpp:2759
Definition: commands_3dm.hpp:749
Definition: commands_3dm.hpp:2572
Definition: commands_3dm.hpp:2079
Definition: commands_3dm.hpp:1356
Definition: commands_3dm.hpp:2682
Definition: commands_3dm.hpp:2433
Definition: commands_3dm.hpp:1315
Definition: commands_3dm.hpp:617
Definition: commands_3dm.hpp:3255
Query
Definition: commands_3dm.hpp:2391
Definition: commands_3dm.hpp:3228
Definition: commands_3dm.hpp:683
Definition: commands_3dm.hpp:2841
Definition: commands_3dm.hpp:3017
@ COMBINATION
Logical combination of two or more triggers. See CombinationParams.
Definition: mip_structures.hpp:67
Definition: commands_3dm.hpp:3466
@ INTERVAL
Trigger at evenly-spaced intervals. Normally used with time fields to trigger periodically....
Definition: commands_3dm.hpp:2207
Mode
Definition: commands_3dm.hpp:2486
Definition: commands_3dm.hpp:3300
@ GPIO
Control the state of a GPIO pin. See GpioParameters.
Definition: commands_3dm.hpp:255
@ WINDOW
Window comparison. Trigger is active if low_thres <= value <= high_thres. If the thresholds are rever...
Definition: commands_3dm.hpp:2809
Mode
Definition: commands_3dm.hpp:2763
Definition: commands_3dm.hpp:2389
Definition: commands_3dm.hpp:725
Mode
Definition: commands_3dm.hpp:2934
Behavior
Definition: commands_3dm.hpp:2060
Definition: commands_3dm.hpp:2719
Type
Definition: commands_3dm.hpp:2782
Definition: commands_3dm.hpp:2243
Type
Definition: commands_3dm.hpp:2966
Definition: commands_3dm.hpp:995
Represents an index ranging from 0..N excluding N.
Definition: index.hpp:28
@ MESSAGE
Output a data packet. See MessageParameters.
Type
Definition: commands_3dm.hpp:2833
Definition: commands_3dm.hpp:2574
AssistedFixOption
Definition: commands_3dm.hpp:1677
Definition: commands_3dm.hpp:2932
Definition: commands_3dm.hpp:2285
Definition: commands_3dm.hpp:4180
Definition: commands_3dm.hpp:3501
Definition: commands_3dm.hpp:2680
Definition: commands_3dm.hpp:3100
Definition: commands_3dm.hpp:2885
Definition: commands_3dm.hpp:2529
Action
Definition: commands_3dm.hpp:1265
Definition: commands_3dm.hpp:3065
Definition: commands_3dm.hpp:1551
Definition: commands_3dm.hpp:1182
Definition: commands_3dm.hpp:1429
Definition: commands_3dm.hpp:3145
Definition: commands_3dm.hpp:1764
Definition: commands_3dm.hpp:4085
Definition: commands_3dm.hpp:2328
Definition: commands_3dm.hpp:795
Definition: commands_3dm.hpp:2604
Definition: commands_3dm.hpp:1553
Definition: commands_3dm.hpp:2761
Definition: commands_3dm.hpp:1675
Definition: commands_3dm.hpp:2641
Definition: commands_3dm.hpp:3910
Definition: commands_3dm.hpp:4049
Definition: commands_3dm.hpp:3335
Feature
Definition: commands_3dm.hpp:2050
Definition: commands_3dm.hpp:1801
Definition: commands_3dm.hpp:2953
Definition: commands_3dm.hpp:3872
ConstellationId
Definition: commands_3dm.hpp:1419
Definition: commands_3dm.hpp:4139
Definition: commands_3dm.hpp:1263
Definition: commands_3dm.hpp:1453
TalkerID
Definition: commands_3dm.hpp:160
Definition: commands_3dm.hpp:145
Definition: commands_3dm.hpp:3963
Definition: commands_3dm.hpp:659
Definition: commands_3dm.hpp:4047
Definition: commands_3dm.hpp:303
Definition: commands_3dm.hpp:3388
Definition: commands_3dm.hpp:2930