-
Notifications
You must be signed in to change notification settings - Fork 128
/
Copy pathosi_logicaldetectiondata.proto
259 lines (223 loc) · 7.92 KB
/
osi_logicaldetectiondata.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
syntax = "proto2";
option optimize_for = SPEED;
import "osi_version.proto";
import "osi_common.proto";
package osi3;
//
// \brief Processed data from one or multiple sensors as a list of logical detections.
// Logical detections are derived from sensor detections in a logical model through processing steps like fusion filtering, tracking etc.
//
// All information is given with respect to the reference frame of the logical/virtual sensor
// \c SensorView::mounting_position (e.g. center of rear axle of the ego car) in Cartesian coordinates.
//
message LogicalDetectionData
{
// The interface version used by the sender (i.e. the simulation
// environment).
//
// \rules
// is_set
// \endrules
//
optional InterfaceVersion version = 1;
// Header attributes of fused detections from multiple sensors and sensor types.
//
optional LogicalDetectionDataHeader header = 2;
// Logical detections consisting of transformed (and potentially fused)
// detections from one or multiple sensors and sensor types.
//
// The parent frame of a logical detection is the virtual sensor coordinate
// system specified by \c SensorView::mounting_position .
//
// /note The virtual sensor coordinate system is relative to the vehicle
// coordinate system which has its origin in the center of the rear axle of
// the ego vehicle. This means if virtual sensor mounting position and
// orientation are set to (0,0,0) the virtual sensor coordinate system
// coincides with the vehicle coordinate system.
//
repeated LogicalDetection logical_detection = 3;
}
//
// \brief The header attributes of each sensor's logical detections list.
//
message LogicalDetectionDataHeader
{
// Time stamp at which the transformation and optional fusion was finished in the global synchronized time.
//
// \note See \c SensorData::timestamp and
// \c SensorData::last_measurement_time for detailed discussions on the
// semantics of time-related fields.
//
optional Timestamp logical_detection_time = 1;
// Data Qualifier expresses to what extent the content of this event can be
// relied on.
//
optional DataQualifier data_qualifier = 2;
// The current number of valid detections in the logical detections list.
//
// \note This value has to be set if the list contains invalid logical detections.
//
// \rules
// is_greater_than_or_equal_to: 0
// \endrules
//
optional uint32 number_of_valid_logical_detections = 3;
// The ID(s) of the sensor(s) that produced the detections for transformation
// and - in case of multiple sensors - fusion into logical detections.
//
repeated Identifier sensor_id = 4;
// Data qualifier communicates the overall availability of the
// interface.
//
enum DataQualifier
{
// Unknown (must not be used in ground truth).
//
DATA_QUALIFIER_UNKNOWN = 0;
// Other (unspecified but known).
//
DATA_QUALIFIER_OTHER = 1;
// Data is available.
//
DATA_QUALIFIER_AVAILABLE = 2;
// Reduced data is available.
//
DATA_QUALIFIER_AVAILABLE_REDUCED = 3;
// Data is not available.
//
DATA_QUALIFIER_NOT_AVAILABLE = 4;
// Sensor is blind.
//
DATA_QUALIFIER_BLINDNESS = 5;
// Sensor temporary available.
//
DATA_QUALIFIER_TEMPORARY_AVAILABLE = 6;
// Sensor invalid.
//
DATA_QUALIFIER_INVALID = 7;
}
}
//
// \brief A logical detection that could be based on multiple sensors and sensor types.
//
message LogicalDetection
{
// Existence probability of the logical detection
//
// \note Use as confidence measure where a low value means less confidence
// and a high value indicates strong confidence.
//
// \rules
// is_greater_than_or_equal_to: 0
// is_less_than_or_equal_to: 1
// \endrules
//
optional double existence_probability = 1;
// ID of the detected object this logical detection is associated to.
//
// \note ID = MAX(uint64) indicates no reference to an object.
//
// \rules
// refers_to: DetectedObject
// \endrules
//
optional Identifier object_id = 2;
// Measured position of the logical detection given in cartesian coordinates
// in the virtual sensor coordinate system.
//
// Unit: m
//
optional Vector3d position = 3;
// Root mean squared error of the measured position of the logical detection.
//
optional Vector3d position_rmse = 4;
// Velocity of the logical detection given in cartesian coordinates in the
// virtual sensor coordinate system.
//
// Unit: m/s
//
optional Vector3d velocity = 5;
// Root mean squared error of the logical detection's velocity.
//
// Unit: m/s
//
// \rules
// is_greater_than_or_equal_to: 0
// \endrules
//
optional Vector3d velocity_rmse = 6;
// Intensity or equivalent value of the logical detection's echo.
//
// Unit: %
//
// \rules
// is_greater_than_or_equal_to: 0
// is_less_than_or_equal_to: 100
// \endrules
//
optional double intensity = 7;
// The signal to noise ratio (SNR) of the logical detection.
//
// Unit: dB
//
optional double snr = 8;
// Describes the possibility whether more than one object may have led to
// this logical detection.
//
// \rules
// is_greater_than_or_equal_to: 0
// is_less_than_or_equal_to: 1
// \endrules
//
optional double point_target_probability = 9;
// The ID(s) of the sensor(s) that produced the detection(s) for transformation
// and - in case of multiple sensors - fusion into the single logical detection.
//
// \note One logical detection can originate from multiple sensors.
//
repeated Identifier sensor_id = 10;
// Basic classification of the logical detection.
//
optional LogicalDetectionClassification classification = 11;
// Echo pulse width of the logical detection's echo.
// Several sensors output an echo pulse width instead of an intensity for each individual detection.
// The echo pulse is measured in m and measures the extent of the object parts or atmospheric particles that produce the echo.
// \note For more details see [1] Fig. 7 and 8.
// \note Fig. 7 shows an example where the two echos are reflected from the edges A-B and C-D.
// \note Fig. 8 shows how the echo pulse width is measured as the range between the rising edge and the falling edge that crosses the intensity threshold.
//
// Unit: m
//
// \rules
// is_greater_than_or_equal_to: 0
// \endrules
//
// \par Reference:
// [1] Rosenberger, P., Holder, M.F., Cianciaruso, N. et al. (2020). <em>Sequential lidar sensor system simulation: a modular approach for simulation-based safety validation of automated driving</em> Automotive Engine Technology 5, Fig 7, Fig 8. Retrieved May 10, 2021, from https://doi.org/10.1007/s41104-020-00066-x
//
optional double echo_pulse_width = 12;
}
// Definition of basic logical detection classifications.
//
enum LogicalDetectionClassification
{
// Logical detection is unknown (must not be used in ground truth).
//
LOGICAL_DETECTION_CLASSIFICATION_UNKNOWN = 0;
// Other (unspecified but known) logical detection.
//
LOGICAL_DETECTION_CLASSIFICATION_OTHER = 1;
// Invalid logical detection, not to be used for object tracking, of unspecified
// type (none of the other types applies).
//
LOGICAL_DETECTION_CLASSIFICATION_INVALID = 2;
// Clutter (noise, spray, rain, fog etc.).
//
LOGICAL_DETECTION_CLASSIFICATION_CLUTTER = 3;
// Over-drivable (ground etc.).
//
LOGICAL_DETECTION_CLASSIFICATION_OVERDRIVABLE = 4;
// Under-drivable (sign gantry etc.).
//
LOGICAL_DETECTION_CLASSIFICATION_UNDERDRIVABLE = 5;
}