Gocator API
 All Classes Files Functions Variables Typedefs Macros Modules Pages
GoHealth.h
Go to the documentation of this file.
1 /**
2  * @file GoHealth.h
3  * @brief Declares the GoHealthMsg class and related types.
4  *
5  * @internal
6  * Copyright (C) 2016-2022 by LMI Technologies Inc.
7  * Licensed under the MIT License.
8  * Redistributed files must retain the above copyright notice.
9  */
10 #ifndef GO_SDK_HEALTH_H
11 #define GO_SDK_HEALTH_H
12 
13 #include <GoSdk/GoSdkDef.h>
14 #include <kApi/Io/kSerializer.h>
15 
16 /**
17  * @struct GoHealthIndicatorId
18  * @ingroup GoSdk-HealthChannel
19  * @brief Represents a health indicator ID.
20  *
21  * The following enumerators are defined:
22  * - #GO_HEALTH_ENCODER_VALUE
23  * - #GO_HEALTH_ENCODER_FREQUENCY
24  * - #GO_HEALTH_LASER_SAFETY
25  * - #GO_HEALTH_FIRMWARE_VERSION
26  * - #GO_HEALTH_FIRESYNC_VERSION
27  * - #GO_HEALTH_UPTIME
28  * - #GO_HEALTH_TEMPERATURE
29  * - #GO_HEALTH_TEMPERATURE_EXTENDED
30  * - #GO_HEALTH_PROJECTOR_TEMPERATURE
31  * - #GO_HEALTH_LASER_TEMPERATURE
32  * - #GO_HEALTH_LASER_OVERHEAT
33  * - #GO_HEALTH_LASER_OVERHEAT_DURATION
34  * - #GO_HEALTH_OVERHEAT
35  * - #GO_HEALTH_OVERHEAT_DURATION
36  * - #GO_HEALTH_CPU_TEMPERATURE
37  * - #GO_HEALTH_CAMERA_0_TEMPERATURE
38  * - #GO_HEALTH_CAMERA_1_TEMPERATURE
39  * - #GO_HEALTH_LASER_DRIVER_TEMPERATURE
40  * - #GO_HEALTH_MEMORY_USED
41  * - #GO_HEALTH_MEMORY_CAPACITY
42  * - #GO_HEALTH_STORAGE_USED
43  * - #GO_HEALTH_STORAGE_CAPACITY
44  * - #GO_HEALTH_CPU_USED
45  * - #GO_HEALTH_SYNC_SOURCE
46  * - #GO_HEALTH_NET_OUT_USED
47  * - #GO_HEALTH_NET_OUT_RATE
48  * - #GO_HEALTH_NET_OUT_CAPACITY
49  * - #GO_HEALTH_NET_OUT_LINK_STATUS
50  * - #GO_HEALTH_DIGITAL_INPUTS
51  * - #GO_HEALTH_EVENT_COUNTS
52  * - #GO_HEALTH_CAMERA_SEARCH_COUNT
53  * - #GO_HEALTH_CAMERA_TRIGGER_DROPS
54  * - #GO_HEALTH_CUDA_STATUS
55  * - #GO_HEALTH_STATE
56  * - #GO_HEALTH_SPEED
57  * - #GO_HEALTH_MAXSPEED
58  * - #GO_HEALTH_SPOT_COUNT
59  * - #GO_HEALTH_MAX_SPOT_COUNT
60  * - #GO_HEALTH_SCAN_COUNT
61  * - #GO_HEALTH_VALID_POINT_COUNT
62  * - #GO_HEALTH_MAX_POINT_COUNT
63  * - #GO_HEALTH_MASTER_STATUS
64  * - #GO_HEALTH_CAST_START_STATE
65  * - #GO_HEALTH_ALIGNMENT_STATE
66  * - #GO_HEALTH_PLAYBACK_POSITION
67  * - #GO_HEALTH_PLAYBACK_COUNT
68  * - #GO_HEALTH_DIGITAL_OUTPUT_HIGH_COUNT
69  * - #GO_HEALTH_DIGITAL_OUTPUT_LOW_COUNT
70  * - #GO_HEALTH_PROCESSING_LATENCY_LAST
71  * - #GO_HEALTH_PROCESSING_LATENCY_MAX
72  * - #GO_HEALTH_PROCESSING_DROPS
73  * - #GO_HEALTH_TRIGGER_DROPS
74  * - #GO_HEALTH_OUTPUT_DROPS
75  * - #GO_HEALTH_ANALOG_DROPS
76  * - #GO_HEALTH_DIGITAL_DROPS
77  * - #GO_HEALTH_SERIAL_DROPS
78  * - #GO_HEALTH_CONTROLLED_TRIGGER_DROPS
79  * - #GO_HEALTH_SURFACE_PROCESSING_TIME
80  * - #GO_HEALTH_MAX_FRAME_RATE
81  * - #GO_HEALTH_ETHERNET_DROPS
82  * - #GO_HEALTH_RANGE_VALID_COUNT
83  * - #GO_HEALTH_RANGE_INVALID_COUNT
84  * - #GO_HEALTH_ANCHOR_INVALID_COUNT
85  * - #GO_HEALTH_LIGHT_OPERATIONAL_TIME_TOTAL
86  * - #GO_HEALTH_FIRST_LOG_ID
87  * - #GO_HEALTH_LAST_LOG_ID
88  * - #GO_HEALTH_ENCODER_Z_INDEX_PULSE_DROPS
89  * - #GO_HEALTH_TOOL_RUN_TIME
90  * - #GO_HEALTH_PART_TOTAL_EMITTED
91  * - #GO_HEALTH_PART_LENGTH_LIMIT
92  * - #GO_HEALTH_PART_MIN_AREA_DROPS
93  * - #GO_HEALTH_PART_BACKTRACK_DROPS
94  * - #GO_HEALTH_PART_CURRENTLY_ACTIVE
95  * - #GO_HEALTH_PART_LENGTH
96  * - #GO_HEALTH_PART_START_Y
97  * - #GO_HEALTH_PART_TRACKING_STATE
98  * - #GO_HEALTH_PART_CAPACITY_EXCEEDED
99  * - #GO_HEALTH_PART_X_POSITION
100  * - #GO_HEALTH_TOOL_RUN_TIME_MIN
101  * - #GO_HEALTH_TOOL_RUN_TIME_MAX
102  * - #GO_HEALTH_TOOL_RUN_TIME_AVERAGE
103  * - #GO_HEALTH_TOOL_RUN_TIME_PERCENT
104  * - #GO_HEALTH_MEASUREMENT
105  * - #GO_HEALTH_MEASUREMENT_PASS
106  * - #GO_HEALTH_MEASUREMENT_FAIL
107  * - #GO_HEALTH_MEASUREMENT_MIN
108  * - #GO_HEALTH_MEASUREMENT_MAX
109  * - #GO_HEALTH_MEASUREMENT_AVERAGE
110  * - #GO_HEALTH_MEASUREMENT_STDEV
111  * - #GO_HEALTH_MEASUREMENT_INVALID_COUNT
112  * - #GO_HEALTH_MEASUREMENT_OVERFLOW_COUNT
113  */
114 typedef k32s GoHealthIndicatorId;
115 /** @name GoHealthIndicatorId
116  *@{*/
117 #define GO_HEALTH_ENCODER_VALUE (1003) ///< Current system encoder tick.
118 #define GO_HEALTH_ENCODER_FREQUENCY (1005) ///< Current system encoder frequency (ticks/s).
119 #define GO_HEALTH_LASER_SAFETY (1010) ///< Laser safety status.
120 
121 #define GO_HEALTH_FIRMWARE_VERSION (2000) ///< Firmware application version.
122 #define GO_HEALTH_FIRESYNC_VERSION (20600) ///< FireSync version
123 
124 #define GO_HEALTH_UPTIME (2017) ///< Time elapsed since boot-up or reset (seconds).
125 
126 #define GO_HEALTH_TEMPERATURE (2002) ///< Internal temperature (degrees Celsius).
127 #define GO_HEALTH_TEMPERATURE_EXTENDED (20009) ///< Internal temperature extended (supports multiple devices, degrees Celsius).
128 #define GO_HEALTH_PROJECTOR_TEMPERATURE (2404) ///< Projector temperature (degrees Celsius).
129 #define GO_HEALTH_LASER_TEMPERATURE (2028) ///< Laser temperature (degrees Celsius). Available only on 3B-class devices.
130 #define GO_HEALTH_LASER_OVERHEAT (20020) ///< Indicates whether the laser is overheating. (DEPRECATED)
131 #define GO_HEALTH_LASER_OVERHEAT_DURATION (20021) ///< Indicates how long the laser has been overheating if it is overheating. (DEPRECATED)
132 #define GO_HEALTH_OVERHEAT (20020) ///< Indicates whether the sensor is overheating.
133 #define GO_HEALTH_OVERHEAT_DURATION (20021) ///< Indicates how long the sensor has been overheating if it is overheating.
134 
135 #define GO_HEALTH_CPU_TEMPERATURE (20011) ///< CPU temperature (degrees Celsius).
136 #define GO_HEALTH_CAMERA_0_TEMPERATURE (20012) ///< Camera 0 temperature (degrees Celsius).
137 #define GO_HEALTH_CAMERA_1_TEMPERATURE (20013) ///< Camera 1 temperature (degrees Celsius).
138 #define GO_HEALTH_LASER_DRIVER_TEMPERATURE (20014) ///< Laser driver temperature (degrees Celsius).
139 
140 #define GO_HEALTH_MEMORY_USED (2003) ///< Amount of memory currently used (bytes).
141 #define GO_HEALTH_MEMORY_CAPACITY (2004) ///< Total amount of memory available (bytes).
142 #define GO_HEALTH_STORAGE_USED (2005) ///< Amount of non-volatile storage used (bytes).
143 #define GO_HEALTH_STORAGE_CAPACITY (2006) ///< Total amount of non-volatile storage available (bytes).
144 #define GO_HEALTH_CPU_USED (2007) ///< CPU usage (percentage of maximum).
145 
146 #define GO_HEALTH_SYNC_SOURCE (2043) ///< Sensor synchronization source. (1 - Master, 2 - Device/Gocator)
147 #define GO_HEALTH_NET_OUT_USED (21003) ///< Current outbound network count (bytes).
148 #define GO_HEALTH_NET_OUT_RATE (21004) ///< Current outbound network throughput (bytes/second).
149 #define GO_HEALTH_NET_OUT_CAPACITY (2009) ///< Total available outbound network throughput (bytes/s).
150 #define GO_HEALTH_NET_OUT_LINK_STATUS (2034) ///< The ethernet output's current network link status
151 
152 #define GO_HEALTH_DIGITAL_INPUTS (2024) ///< Current digital input status (one bit per input).
153 #define GO_HEALTH_EVENT_COUNTS (2102) ///< Total number of events triggered.
154 #define GO_HEALTH_CAMERA_SEARCH_COUNT (2217) ///< Number of search states.
155 #define GO_HEALTH_CAMERA_TRIGGER_DROPS (2201) ///< Number of dropped triggers.
156 
157 #define GO_HEALTH_CUDA_STATUS (3007) ///< Status of CUDA/GPU support on the sensor (accelerated and non-accelerated) platform.
158 
159 #define GO_HEALTH_STATE (20000) ///< Current system state.
160 #define GO_HEALTH_SPEED (20001) ///< Current speed (Hz).
161 #define GO_HEALTH_MAXSPEED (20002) ///< Maximum speed (Hz).
162 #define GO_HEALTH_SPOT_COUNT (20003) ///< Number of found spots in the last raw/unresampled profile/surface
163 #define GO_HEALTH_MAX_SPOT_COUNT (20004) ///< Maximum number of spots that can be found
164 #define GO_HEALTH_SCAN_COUNT (20005) ///< The number of scanned profiles or surfaces.
165 #define GO_HEALTH_VALID_POINT_COUNT (20015) ///< The number of found points in the last resampled profile/surface
166 #define GO_HEALTH_MAX_POINT_COUNT (20016) ///< Maximum number of points that can be found
167 
168 #define GO_HEALTH_MASTER_STATUS (20006) ///< Master connection status: 0=not connected, 1=connected
169 #define GO_HEALTH_CAST_START_STATE (20007) ///< The state of the second digital input.
170 #define GO_HEALTH_ALIGNMENT_STATE (20008) ///< The state of the sensor alignment.
171 
172 #define GO_HEALTH_PLAYBACK_POSITION (20023) ///< Indicates the current replay playback index.
173 #define GO_HEALTH_PLAYBACK_COUNT (20024) ///< Indicates the number of frames present in the current replay.
174 
175 #define GO_HEALTH_DIGITAL_OUTPUT_HIGH_COUNT (21006) ///< The number scans with high digital output pulses.
176 #define GO_HEALTH_DIGITAL_OUTPUT_LOW_COUNT (21007) ///< The number scans with no digital output pulse.
177 
178 #define GO_HEALTH_PROCESSING_LATENCY_LAST (21001) ///< Last reported processing latency value (in uS).
179 #define GO_HEALTH_PROCESSING_LATENCY_MAX (21002) ///< Maximum reported processing latency.
180 #define GO_HEALTH_PROCESSING_DROPS (21000) ///< Current number of processing drops.
181 #define GO_HEALTH_TRIGGER_DROPS (21010) ///< Current number of trigger drops.
182 #define GO_HEALTH_OUTPUT_DROPS (21011) ///< Current number of output drops. Sum of all output drops.
183 
184 #define GO_HEALTH_ANALOG_DROPS (21014) ///< Current number of analog output drops. Replaces GO_HEALTH_ANALOG_DROPS.
185 #define GO_HEALTH_DIGITAL_DROPS (21015) ///< Current number of digital output drops. Replaces GO_HEALTH_DIGITAL_DROPS.
186 #define GO_HEALTH_SERIAL_DROPS (21016) ///< Current number of serial output drops. Replaces GO_HEALTH_SERIAL_DROPS.
187 #define GO_HEALTH_CONTROLLED_TRIGGER_DROPS (21017) ///< Trigger drops from the Controlled Triggering System.
188 #define GO_HEALTH_SURFACE_PROCESSING_TIME (21018) ///< Processing time of frame on 35XX/32XX (microseconds).
189 #define GO_HEALTH_MAX_FRAME_RATE (21019) ///< Max configurable frame rate (scaled by 0.000001).
190 #define GO_HEALTH_ETHERNET_DROPS (21005) ///< Current number of ethernet output drops.
191 
192 #define GO_HEALTH_RANGE_VALID_COUNT (21100) ///< Current number of frames with valid range data.
193 #define GO_HEALTH_RANGE_INVALID_COUNT (21101) ///< Current number of frames with invalid range data.
194 #define GO_HEALTH_ANCHOR_INVALID_COUNT (21200) ///< Number of frames with anchor invalid.
195 #define GO_HEALTH_LIGHT_OPERATIONAL_TIME_TOTAL (21201) ///< For G2 laser on time or G3 projector on time.
196 
197 #define GO_HEALTH_FIRST_LOG_ID (21301) ///< ID of first available log entry
198 #define GO_HEALTH_LAST_LOG_ID (21300) ///< ID of last available log entry
199 
200 #define GO_HEALTH_ENCODER_Z_INDEX_PULSE_DROPS (22000) ///< Encoder z-index pulse drops
201 
202 #define GO_HEALTH_TOOL_RUN_TIME (22004) ///< Most recent time taken to execute the tool
203 #define GO_HEALTH_PART_TOTAL_EMITTED (22006) ///< Total number of parts emitted
204 #define GO_HEALTH_PART_LENGTH_LIMIT (22007) ///< Number of parts emitted based on length limit
205 #define GO_HEALTH_PART_MIN_AREA_DROPS (22008) ///< Number of parts dropped
206 #define GO_HEALTH_PART_BACKTRACK_DROPS (22009) ///< Number of parts dropped due to backtracking
207 #define GO_HEALTH_PART_CURRENTLY_ACTIVE (22010) ///< Number of parts currently being tracked
208 #define GO_HEALTH_PART_LENGTH (22011) ///< Length of largest active part
209 #define GO_HEALTH_PART_START_Y (22012) ///< Start Y position of largest active part
210 #define GO_HEALTH_PART_TRACKING_STATE (22013) ///< Tracking state of largest active part
211 #define GO_HEALTH_PART_CAPACITY_EXCEEDED (22014) ///< Part detection capacity exceeded
212 #define GO_HEALTH_PART_X_POSITION (22015) ///< Center X position of largets active part
213 #define GO_HEALTH_TOOL_RUN_TIME_MIN (22016) ///< Minimum time for tool to process a sample
214 #define GO_HEALTH_TOOL_RUN_TIME_MAX (22017) ///< Maximum time for tool to process a sample
215 #define GO_HEALTH_TOOL_RUN_TIME_AVERAGE (22018) ///< Average time for tool to process a sample
216 #define GO_HEALTH_TOOL_RUN_TIME_PERCENT (22019) ///< Average percentage of total time running the tool
217 
218 #define GO_HEALTH_MEASUREMENT (30000) ///< Measurement value.
219 #define GO_HEALTH_MEASUREMENT_PASS (30001) ///< Number of pass decisions.
220 #define GO_HEALTH_MEASUREMENT_FAIL (30002) ///< Number of fail decisions.
221 #define GO_HEALTH_MEASUREMENT_MIN (30003) ///< Minimum measurement value.
222 #define GO_HEALTH_MEASUREMENT_MAX (30004) ///< Maximum measurement value.
223 #define GO_HEALTH_MEASUREMENT_AVERAGE (30005) ///< Average measurement value.
224 #define GO_HEALTH_MEASUREMENT_STDEV (30006) ///< Measurement value standard deviation.
225 #define GO_HEALTH_MEASUREMENT_INVALID_COUNT (30007) ///< Number of invalid values.
226 #define GO_HEALTH_MEASUREMENT_OVERFLOW_COUNT (30008) ///< Number of values which exceed the numerical limit of an output protocol's measurement value field.
227 /**@}*/
228 
229 
230 /**
231  * @struct GoIndicator
232  * @extends kValue
233  * @ingroup GoSdk-HealthChannel
234  * @brief Represents health indicator.
235  */
236 typedef struct GoIndicator
237 {
238  k32u id; ///< Indicator ID (e.g. GO_HEALTH_CPU_USED)
239  k32u instance; ///< Indicator instance number.
240  k64s value; ///< Indicator value.
241 } GoIndicator;
242 
243 /**
244  * @class GoHealthMsg
245  * @extends kObject
246  * @ingroup GoSdk-HealthChannel
247  * @brief Represents health information from a single sensor.
248  */
249 typedef kObject GoHealthMsg;
250 
251 /**
252  * Gets the health source.
253  *
254  * @public @memberof GoHealthMsg
255  * @version Introduced in firmware 4.0.10.27
256  * @param msg Message object.
257  * @return Health source.
258  */
260 
261 /**
262  * Count of health indicators in this message.
263  *
264  * @public @memberof GoHealthMsg
265  * @version Introduced in firmware 4.0.10.27
266  * @param msg Message object.
267  * @return Count of indicators.
268  */
270 
271 /**
272  * Gets the health indicator at the specified index.
273  *
274  * @public @memberof GoHealthMsg
275  * @version Introduced in firmware 4.0.10.27
276  * @param msg Message object.
277  * @param index Indicator index.
278  * @return Indicator pointer.
279  */
280 GoFx(GoIndicator*) GoHealthMsg_At(GoHealthMsg msg, kSize index);
281 
282 /**
283  * Finds the health indicator with the matching ID. Returns kNULL if not found.
284  *
285  * @public @memberof GoHealthMsg
286  * @version Introduced in firmware 4.0.10.27
287  * @param msg Message object.
288  * @param id Indicator index.
289  * @param instance Indicator instance.
290  * @return Indicator pointer.
291  */
292 GoFx(GoIndicator*) GoHealthMsg_Find(GoHealthMsg msg, k32u id, k32u instance);
293 
294 #include <GoSdk/Messages/GoHealth.x.h>
295 
296 #endif
kSize GoHealthMsg_Count(GoHealthMsg msg)
Count of health indicators in this message.
Represents health information from a single sensor.
Represents health indicator.
Definition: GoHealth.h:236
Represents a data source.
Essential SDK declarations.
GoIndicator * GoHealthMsg_Find(GoHealthMsg msg, k32u id, k32u instance)
Finds the health indicator with the matching ID.
GoDataSource GoHealthMsg_Source(GoHealthMsg msg)
Gets the health source.
Represents a health indicator ID.
k32u id
Indicator ID (e.g. GO_HEALTH_CPU_USED)
Definition: GoHealth.h:238
GoIndicator * GoHealthMsg_At(GoHealthMsg msg, kSize index)
Gets the health indicator at the specified index.
k32u instance
Indicator instance number.
Definition: GoHealth.h:239
k64s value
Indicator value.
Definition: GoHealth.h:240