forked from boston-dynamics/spot-sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdata_acquisition.proto
503 lines (404 loc) · 18.8 KB
/
data_acquisition.proto
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
// Copyright (c) 2023 Boston Dynamics, Inc. All rights reserved.
//
// Downloading, reproducing, distributing or otherwise using the SDK Software
// is subject to the terms and conditions of the Boston Dynamics Software
// Development Kit License (20191101-BDSDK-SL).
syntax = "proto3";
package bosdyn.api;
option java_outer_classname = "DataAcquisitionProto";
import "bosdyn/api/alerts.proto";
import "bosdyn/api/header.proto";
import "bosdyn/api/image.proto";
import "bosdyn/api/network_compute_bridge.proto";
import "bosdyn/api/service_customization.proto";
import "bosdyn/api/signals.proto";
import "google/protobuf/any.proto";
import "google/protobuf/duration.proto";
import "google/protobuf/struct.proto";
import "google/protobuf/timestamp.proto";
// Description of a data acquisition capability. A data acquisition plugin service will have a
// set of capabilities for which it can acquire and save the appropriate data.
message DataAcquisitionCapability {
// Unique identifier for the data acquisition capability. Used for identification purposes
// when making acquire data requests.
string name = 1;
// A human readable name of the data acquisition capability that will be shown on the tablet.
string description = 2;
// Channel name that will be associated with all data stored in the data buffer through
// each data acquisition plugin. Metadata acquirers do not specify this field.
string channel_name = 3;
// The data acquisition plugin service's service name used in directory registration.
string service_name = 4;
// Custom parameters supported by this instance of the service.
DictParam.Spec custom_params = 5;
// Capability has live data available via GetLiveData RPC.
bool has_live_data = 6;
}
// Description of an image acquisition capability. The image acquisition capabilities will be
// available through the main data acquisition service on robot and are populated based on all
// bosdyn.api.ImageService services registered to the robot's directory.
message ImageAcquisitionCapability {
// The image service's service name used in directory registration.
string service_name = 1;
// DEPRECATED as of 3.1.0. Please use "image_sources" below for information regarding the image
// source associated with the service.
repeated string image_source_names = 2 [deprecated = true];
// List of image sources reported by the image service (through the ListImageSources RPC).
repeated ImageSource image_sources = 3;
}
message NetworkComputeCapability {
// Service information.
NetworkComputeServerConfiguration server_config = 1;
// Provide list of available models.
// DEPRECATED as of 3.3. Replaced by AvailableModels.
repeated string available_models = 2 [deprecated = true];
// Information about available classes for each model.
// DEPRECATED as of 3.3. Replaced by AvailableModels.
repeated ModelLabels labels = 6 [deprecated = true];
// Envelope message for repeated ModelData.
AvailableModels models = 3;
}
// A list of all capabilities (data and images) that a specific data acquisition plugin service can
// successfully acquire and save the data specified in each capability.
message AcquisitionCapabilityList {
// List of non-image data acquisition capabilities.
repeated DataAcquisitionCapability data_sources = 1;
// List of image data acquisition capabilities.
repeated ImageAcquisitionCapability image_sources = 3;
// List of network compute capabilities.
repeated NetworkComputeCapability network_compute_sources = 5;
}
// The CaptureActionId describes the entire capture action for an AcquireData request and will be
// used to uniquely identify that full request's set of stored data.
message CaptureActionId {
// The action name is used to group all pieces of data associated with a single AcquireData
// request. The action name must be unique for the given group name, meaning no two actions
// with the same group name can have the same action name.
string action_name = 1;
// The group name is used to group a "session" of data, such as a mission or a teleop capture
// session, which includes multiple capture actions (from multiple AcquireData RPCs).
string group_name = 2;
// Time (in the robot's clock) at which this capture was triggered. If the timestamp is not
// specified in the AcquireData RPC, the main data acquisition service on robot will populate
// the timestamp field with the timestamp of when the RPC was received.
google.protobuf.Timestamp timestamp = 3;
reserved 4;
}
// A way to identify an individual piece of data stored in the data buffer.
message DataIdentifier {
// The action where the data was acquired.
CaptureActionId action_id = 1;
// Data buffer channel associated with the DataBlob. The channel is used to group data across
// actions by a specific source, and it can be used in queries to retrieve some subset of data.
// For example, the channel could be "ptz" and queries can be made for all PTZ images.
string channel = 2;
// Data-specific identifier that can optionally be used to disambiguate cases where the
// action_id and channel are insufficient. For example, you save cropped SpotCAM pano image that
// are detected as gauges to a "detected_gauges" channel, but want a way to further individually
// identify them as each specific gauge, so you give each detection a unique data_name.
string data_name = 3;
// Unique identifier specified by the Data Acquisition Store service for this individual piece
// of data. It is a monotonically-increasing value that is incremented for each stored capture.
// This value is intended to be unique to a robot and not globally unique. We do not guarantee
// uniqueness pre and post software upgrades or factory resets. This id does not necessarily
// start at 0.
uint64 id = 4;
}
// Structured data that can be included within a AcquireData RPC and saved in association with
// that capture action.
message Metadata {
// JSON representation of metadata.
google.protobuf.Struct data = 1;
}
// This message can be stored as a DataBlob in the data buffer in order to be recognized as
// metadata that is associated with previously stored data.
message AssociatedMetadata {
// The data that this metadata refers to.
// The timestamp field is ignored.
// If only the action_id is filled out, this metadata is associated with the entire capture
// action.
DataIdentifier reference_id = 1;
// Metadata message to be stored.
Metadata metadata = 2;
}
// This message can be stored as a DataBlob in the data buffer in order to be recognized as
// AlertData that is associated with previously stored data.
message AssociatedAlertData {
// The data that this AlertData refers to.
// The timestamp field is ignored.
// If only the action_id is filled out, this AlertData is associated with the entire capture
// action.
DataIdentifier reference_id = 1;
// AlertData message to be stored.
AlertData alert_data = 2;
}
// An individual capture which can be specified in the AcquireData request to identify a piece of
// image data to be collected.
message ImageSourceCapture {
// Name of the image service that the data should be requested from.
string image_service = 1;
// Options for requesting this particular image.
ImageRequest image_request = 4;
// DEPRECATED as of 3.2.0. Use image_request instead.
// Specific image source to use from the list reported by the image service within the
// ImageAcquisitionCapability message.
string image_source = 2 [deprecated = true];
// DEPRECATED as of 3.2.0. Use image_request instead.
// Specific pixel format to capture reported by the ImageAcquisitionCapability message.
Image.PixelFormat pixel_format = 3 [deprecated = true];
}
// An individual capture which can be specified in the AcquireData or LiveData request to identify
// a piece of non-image data to be collected.
message DataCapture {
// Name of the data to be captured. This should match the uniquely identifying name from
// the DataAcquisitionCapability.
string name = 1;
// Values passed to the service at capture time.
// See the DictParam.Spec in DataAcquisitionCapability.
DictParam custom_params = 9;
}
message NetworkComputeCapture {
// Data source and model.
oneof input {
// DEPRECATED as of 3.3. Please use input_data_bridge instead.
NetworkComputeInputData input_data = 1 [deprecated = true];
NetworkComputeInputDataBridge input_data_bridge = 3;
}
// Which service to use.
NetworkComputeServerConfiguration server_config = 2;
}
// The grouping of all individual image and data captures for a given capture action.
message AcquisitionRequestList {
// List of image requests.
repeated ImageSourceCapture image_captures = 1;
// List of non-image data and metadata requests.
repeated DataCapture data_captures = 2;
// List of Network Compute Bridge requests
repeated NetworkComputeCapture network_compute_captures = 4;
}
// An error associated with a particular capture action and piece of data.
message DataError {
// Identifier for the data to be saved.
DataIdentifier data_id = 1;
// Human-readable message describing the error.
// If a capability was misconfigured, e.g. by an invalid CustomParam in one of the requests,
// it should show up here.
string error_message = 2;
// Custom plugin-specific data about the problem.
google.protobuf.Any error_data = 3;
}
// An error associated with a particular data acquisition plugin service that was
message PluginServiceError {
// Name of the service with the error
string service_name = 1;
// Possible ways a plugin can fail.
enum ErrorCode {
STATUS_UNKNOWN = 0;
// The initial RPC to the plugin failed
STATUS_REQUEST_ERROR = 1;
// The GetStatus request to the plugin failed with a data error or timeout.
STATUS_GETSTATUS_ERROR = 2;
// The plugin reported an internal error.
STATUS_INTERNAL_ERROR = 3;
}
// Failure mode.
ErrorCode error = 2;
// Description of the error.
string message = 3;
}
message NetworkComputeError {
// Name of the service with the error
string service_name = 1;
enum ErrorCode {
STATUS_UNKNOWN = 0;
// The request was rejected.
STATUS_REQUEST_ERROR = 1;
// The request had an error reaching the worker.
STATUS_NETWORK_ERROR = 2;
// Some other problem prevented the request from succeeding.
STATUS_INTERNAL_ERROR = 3;
}
// General type of error that occurred.
ErrorCode error = 2;
// Any particular failure mode reported.
NetworkComputeStatus network_compute_status = 3;
// Description of the error.
string message = 4;
}
message AcquireDataRequest {
// Common request header.
RequestHeader header = 1;
// Define the unique action that all data should be saved with.
CaptureActionId action_id = 2;
// Metadata to store with the data capture. The main Data Acquisition service saves it in the
// DataBuffer.
Metadata metadata = 3;
// List of capability requests that should be collected as part of this capture action.
AcquisitionRequestList acquisition_requests = 4;
// Optional duration used to extend the amount of time that the data request may take, in
// the event that a plugin is incorrectly specifying its timeout.
// The amount of time allowed will be the maximum of this duration and any requests
// made to plugins or other capture sources.
google.protobuf.Duration min_timeout = 5;
}
message AcquireDataResponse {
// Common response header
ResponseHeader header = 1;
enum Status {
STATUS_UNKNOWN = 0;
// The capture action has successfully started acquiring the data.
STATUS_OK = 1;
// One of the capability requests in the AcquisitionRequestList is unknown.
STATUS_UNKNOWN_CAPTURE_TYPE = 2;
}
// Result of the AcquirePluginData RPC call. Further monitoring on the success of the
// acquisition request can be done using the GetStatus RPC.
Status status = 2;
// Identifier which can be used to check the status of or cancel the acquisition action.
uint32 request_id = 3;
}
// Message sent by main Data Acquisition service to all data acquisition plugin services.
message AcquirePluginDataRequest {
// Common request header
RequestHeader header = 1;
// Metadata acquirers use these DataIdentifier objects to associate them with the acquired
// metadata when storing them in the DataBuffer.
// Data acquirers simply get the timestamp from these DataIdentifier objects to use when
// storing the data in the DataBuffer.
repeated DataIdentifier data_id = 2;
// Metadata specified by the requester.
Metadata metadata = 3;
// Id to be associated with all the data buffered for this request. It will be stored
// in the DataIdentifier field of each piece of data buffered from this request.
CaptureActionId action_id = 4;
// List of capability requests specific for this Data Acquisition plugin.
AcquisitionRequestList acquisition_requests = 5;
}
message AcquirePluginDataResponse {
// Common response header
ResponseHeader header = 1;
enum Status {
STATUS_UNKNOWN = 0;
// The capture action has successfully started acquiring the data.
STATUS_OK = 1;
// One of the capability requests in the AcquisitionRequestList is unknown.
STATUS_UNKNOWN_CAPTURE_TYPE = 2;
// See custom_param_error field for details.
STATUS_CUSTOM_PARAMS_ERROR = 3;
}
// Result of the AcquirePluginData RPC call. Further monitoring on the success of the
// acquisition request can be done using the GetStatus RPC.
Status status = 2;
// Identifier which can be used to check the status of or cancel the acquisition action..
uint32 request_id = 3;
// Time (in the robot's clock) by which this capture should definitely be complete.
// If it is not complete by this time, something has gone wrong.
google.protobuf.Timestamp timeout_deadline = 5;
// Filled out if status is STATUS_CUSTOM_PARAMS_ERROR.
CustomParamError custom_param_error = 6;
}
message GetStatusRequest {
// Common request header
RequestHeader header = 1;
// Which acquisition to check the status of.
uint32 request_id = 2;
}
message GetStatusResponse {
// Common response header
ResponseHeader header = 1;
enum Status {
STATUS_UNKNOWN = 0;
// [Status]
STATUS_ACQUIRING = 1; // Data acquisition is still in progress.
STATUS_SAVING = 2; // Data has been acquired, processing and storage is now in progress.
STATUS_COMPLETE = 3; // Data acquisition is complete.
STATUS_CANCEL_IN_PROGRESS = 4; // The data acquisition service is cancelling the request.
STATUS_ACQUISITION_CANCELLED = 5; // The data acquisition request was cancelled manually.
// [Error - AcquireData]
STATUS_DATA_ERROR = 10; // An error occurred while acquiring, processing, or saving data.
STATUS_TIMEDOUT = 11; // The data collection has passed the deadline for completion.
STATUS_INTERNAL_ERROR = 12; // An error occurred such that we don't even know our status.
// [Error - CancelAcquisition]
STATUS_CANCEL_ACQUISITION_FAILED = 30; // The cancellation request failed to complete.
// [Error - GetStatus]
STATUS_REQUEST_ID_DOES_NOT_EXIST = 20; // The request_id does not exist.
};
Status status = 2;
// Data that has been successfully saved into the data buffer for the capture action.
repeated DataIdentifier data_saved = 3;
// A list of data captures which have failed in some way during the action.
// For example, the data acquisition plugin is unable to communicate to a sensor and responds
// with a data error for that specific data capture.
repeated DataError data_errors = 9;
// Services which failed independent of a particular data id.
// For example, if a plugin times out or crashes, it could be reported here.
repeated PluginServiceError service_errors = 10;
// Network compute services which failed independent of a particular data id.
// For example, if a worker times out or crashes, it could be reported here.
repeated NetworkComputeError network_compute_errors = 11;
}
message GetServiceInfoRequest {
// Common request header
RequestHeader header = 1;
}
message GetServiceInfoResponse {
// Common response header.
ResponseHeader header = 1;
// List of capabilities that the data acquisition (plugin) service can
// collect and save data for.
AcquisitionCapabilityList capabilities = 2;
}
message CancelAcquisitionRequest {
// Common request header
RequestHeader header = 1;
// Which acquisition request to cancel.
uint32 request_id = 2;
}
message CancelAcquisitionResponse {
// Common response header
ResponseHeader header = 1;
enum Status {
STATUS_UNKNOWN = 0;
STATUS_OK = 1; // Successfully cancelled the data acquisition request.
STATUS_FAILED_TO_CANCEL = 2; // Unable to stop the data acquisition request.
STATUS_REQUEST_ID_DOES_NOT_EXIST = 3; // [Error] The request_id does not exist.
};
// The status of the Cancellation RPC. Further monitoring on the success of the cancellation
// request can be done using the GetStatus RPC.
Status status = 2;
}
// Request live data from a DAQ plugin service by DataCapture capability name.
message LiveDataRequest {
// Common request header.
RequestHeader header = 1;
// Include capability name and parameter values.
repeated DataCapture data_captures = 3;
reserved 2;
}
// Live data response of a DAQ plugin service for a single capability.
message LiveDataResponse {
// Common response header.
ResponseHeader header = 1;
message CapabilityLiveData {
// Map of signal id to signal specification and data.
map<string, Signal> signals = 1;
// Unique name of the data that is captured.
string name = 2;
enum Status {
STATUS_UNKNOWN = 0;
STATUS_OK = 1;
// The capability name is unknown.
STATUS_UNKNOWN_CAPTURE_TYPE = 2;
// See custom_param_error field for details.
STATUS_CUSTOM_PARAMS_ERROR = 3;
// Some other problem occurred.
STATUS_INTERNAL_ERROR = 4;
}
Status status = 3;
// Filled out if status is STATUS_CUSTOM_PARAMS_ERROR.
CustomParamError custom_param_error = 4;
}
// One entry for each data capture in the request. Order matches LiveDataRequest order.
repeated CapabilityLiveData live_data = 3;
reserved 2;
}