Dreamview is a web application that,
- visualizes the current output of relevant autonomous driving modules, e.g. planning trajectory, car localization, chassis status, etc.
- provides human-machine interface for users to view hardware status, turn on/off of modules, and start the autonomous driving car.
- provides debugging tools, such as PnC Monitor to efficiently track module issues.
The application layout is divided into several regions: header, sidebar, main view, and tool view.
The Header has 3 drop-downs that can be set as shown:
The Co-Driver switch is used to detect disengagement event automatically. Once detected, Dreamview will display a pop-up of the data recorder window for the co-driver to enter a new drive event.
Depending on the mode chosen from the mode selector, the corresponding modules and commands, defined in hmi.conf, will be presented in the Module Controller, and Quick Start, respectively.
Note: navigation mode is for the purpose of the low-cost feature introduced in Apollo 2.5. Under this mode, Baidu (or Google) Map presents the absolute position of the ego-vehicle, while the main view has all objects and map elements presented in relative positions to the ego-vehicle.
Sidebar panel controls what is displayed in the tool view described below:
All the tasks that you could perform in DreamView:
-
Quick Start: commands supported from the selected mode. In general, setup: turns on all modules
reset all: turns off all modules
start auto: starts driving the vehicle autonomously
-
Others: switches and buttons for tools used frequently
-
Module Delay: the time delay between two messages for each topic
-
Console: monitor messages from the Apollo platform
A panel to view the hardware status and turn the modules on/off
A toggle menu for visual elements displays.
A visual tool to plan a route before sending the routing request to the Routing module
A panel to report issues to drive event topic ("/apollo/drive_event") to rosbag.
List of predefined routes or single points, known as point of interest (POI).
If route editing is on, routing point(s) can be added visually on the map.
If route editing is off, clicking a desired POI will send a routing request to the server. If the selected POI contains only a point, the start point of the routing request is the current position of the autonomous car; otherwise, the start position is the first point from the desired route.
To edit POIs, see default_end_way_point.txt file under the directory of the Map. For example, if the map selected from the map selector is "Demo", then default_end_way_point.txt is located under modules/map/data/demo
.
Main view animated 3D computer graphics in a web browser.
Elements in the main view are listed in the table below:
Decision fences reflect decisions made by planning module to ego-vehicle (main) and obstacles (objects). Each type of decision is presented in different color and icon as shown below:
Changing lane is a special decision and hence, instead of having decision fence, a change lane icon shows on the autonomous car:
Visual Element | Depiction Explanation |
---|---|
![]() |
|
![]() |
|
When a yield decision is made based on the "Right of Way" laws at a stop-sign intersection, the obstacles to be yielded will have the yield icon on top:
Visual Element | Depiction Explanation |
---|---|
![]() |
Obstacle to yield at stop sign |
When a STOP decision fence is shown, the reason to stop is displayed on the right side of the stop icon. Possible reasons and the corresponding icons are:
Main view that reflects the point of view chosen from Layer Menu:
Visual Element | Point of View |
---|---|
![]() |
|
![]() |
|
![]() |
|
![]() |
Map
|
Shortcut Keys | Description |
---|---|
1 | Toggle Task panel |
2 | Toggle Module Controller panel |
3 | Toggle Layer Menu panel |
4 | Toggle Route Editing panel |
5 | Toggle Data Recorder panel |
6 | Toggle Audio Capture panel |
7 | Toggle Default Routing panel |
v | Rotate Point of View options |