In nuImages, we annotate objects with 2d boxes, instance masks and 2d segmentation masks. All the labels and attributes from nuScenes are carried over into nuImages. We have also added more attributes in nuImages. For segmentation, we have included "stuff" (background) classes.
nuImages contains the same object classes as nuScenes, while the attributes are a superset of the attributes in nuScenes.
- Draw bounding boxes around all objects that are in the list of object classes.
- Do not apply more than one box to a single object.
- If an object is occluded, then draw the bounding box to include the occluded part of the object according to your best guess.
- If an object is cut off at the edge of the image, then the bounding box should stop at the image boundary.
- If an object is reflected clearly in a glass window, then the reflection should be annotated.
- If an object has extremities, the bounding box should include all the extremities (exceptions are the side view mirrors and antennas of vehicles). Note that this differs from how the instance masks are annotated, in which the extremities are included in the masks.
- Only label objects if the object is clear enough to be certain of what it is. If an object is so blurry it cannot be known, do not label the object.
- Do not label an object if its height is less than 10 pixels.
- Do not label an object if its less than 20% visible, unless you can confidently tell what the object is. An object can have low visibility when it is occluded or cut off by the image. The clarity and orientation of the object does not influence its visibility.
human.pedestrian.*
- In nighttime images, annotate the pedestrian only when either the body part(s) of a person is clearly visible (leg, arm, head etc.), or the person is clearly in motion.
vehicle.*
- In nighttime images, annotate a vehicle only when a pair of lights is clearly visible (break or head or hazard lights), and it is clearly on the road surface.
- Given a bounding box, outline the visible parts of the object enclosed within the bounding box using a polygon.
- Each pixel on the image should be assigned to at most one object instance (i.e. the polygons should not overlap).
- There should not be a discrepancy of more than 2 pixels between the edge of the object instance and the polygon.
- If an object is occluded by another object whose width is less than 5 pixels (e.g. a thin fence), then the external object can be included in the polygon.
- If an object is loosely covered by another object (e.g. branches, bushes), do not create several polygons for visible areas that are less than 15 pixels in diameter.
- If an object enclosed by the bounding box is occluded by another foreground object but has a visible area through a glass window (like for cars / vans / trucks), do not create a polygon on that visible area.
- If an object has a visible area through a hole of another foreground object, create a polygon on the visible area. Exemptions would be holes from bicycle / motorcycles / bike racks and holes that are less than 15 pixels diameter.
- If a static / moveable object has another object attached to it (signboard, rope), include it in the annotation.
- If parts of an object are not visible due to lighting and / or shadow, it is best to have an educated guess on the non-visible areas of the object.
- If an object is reflected clearly in a glass window, then the reflection should be annotated.
vehicle.*
- Include extremities (e.g. side view mirrors, taxi heads, police sirens, etc.); exceptions are the crane arms on construction vehicles.
static_object.bicycle_rack
- All bicycles in a bicycle rack should be annotated collectively as bicycle rack.
- Note: A previous version of this taxonomy did not include bicycle racks and therefore some images are missing bicycle rack annotations. We leave this class in the dataset, as it is merely an ignore label. The ignore label is used to avoid punishing false positives or false negatives on bicycle racks, where individual bicycles are difficult to identify.
In nuImages, each object comes with a box, a mask and a set of attributes. The following attributes are in addition to the existing ones in nuScenes:
Attribute | Short Description |
---|---|
vehicle_light.emergency.flashing | The emergency lights on the vehicle are flashing. |
vehicle_light.emergency.not_flashing | The emergency lights on the vehicle are not flashing. |
vertical_position.off_ground | The object is not in the ground (e.g. it is flying, falling, jumping or positioned in a tree or on a vehicle). |
vertical_position.on_ground | The object is on the ground plane. |
nuImages includes surface classes as well:
Label | Short Description |
---|---|
flat.driveable_surface |
All paved or unpaved surfaces that a car can drive on with no concern of traffic rules. |
vehicle.ego |
The vehicle on which the sensors are mounted, that are sometimes visible at the bottom of the image. |
- Only annotate a surface if its length and width are both greater than 20 pixels.
- Annotations should tightly bound the edges of the area(s) of interest.
- If two areas/objects of interest are adjacent to each other, there should be no gap between the two annotations.
- Annotate a surface only as far as it is clearly visible.
- If a surface is occluded (e.g. by branches, trees, fence poles), only annotate the visible areas (which are more than 20 pixels in length and width).
- If a surface is covered by dirt or snow of less than 20 cm in height, include the dirt or snow in the annotation (since it can be safely driven over).
- If a surface has puddles in it, always include them in the annotation.
- Do not annotate reflections of surfaces.
flat.driveable_surface
- Include surfaces blocked by road blockers or pillars as long as they are the same surface as the driveable surface.