Contenuto principale

Simulation 3D Scene Configuration

Scene configuration for 3D simulation environment

  • Simulation 3D Scene Configuration block

Libraries:
Offroad Autonomy Library / Simulation 3D
Aerospace Blockset / Animation / Simulation 3D
Automated Driving Toolbox / Simulation 3D
Robotics System Toolbox / Simulation 3D
Simulink 3D Animation / Simulation 3D / Environment
UAV Toolbox / Simulation 3D
Vehicle Dynamics Blockset / Vehicle Scenarios / Sim3D / Sim3D Core

Description

Note

Simulating models with the Simulation 3D Scene Configuration block requires Simulink® 3D Animation™.

The Simulation 3D Scene Configuration block implements a 3D simulation environment that is rendered by using the Unreal Engine® from Epic Games®. Automated Driving Toolbox™ integrates the 3D simulation environment with Simulink so that you can query the world around the vehicle and virtually test perception, control, and planning algorithms. Using this block, you can also control the position of the sun and the weather conditions of a scene. For more details, see Sun Position and Weather.

You can simulate from a set of prebuilt scenes or from your own custom scenes. Scene customization requires the Automated Driving Toolbox Interface for Unreal Engine Projects support package. For more details, see Customize Unreal Engine Scenes for Automated Driving.

You can also simulate custom scenes designed and built in RoadRunner. To do so, you must first export scenes from RoadRunner and specify the path to the exported scene artifacts in the Project parameter of the Simulation 3D Scene Configuration block.

Tip

The Simulation 3D Scene Configuration block must execute after blocks that send data to the 3D environment and before blocks that receive data from the 3D environment. To verify the execution order of such blocks, right-click the blocks and select Properties. Then, on the General tab, confirm these Priority settings:

  • For blocks that send data to the 3D environment, such as Simulation 3D Vehicle with Ground Following blocks, Priority must be set to -1 so the blocks can prepare their data before the 3D environment receives it.

  • For the Simulation 3D Scene Configuration block in your model, Priority must be set to 0.

  • For blocks that receive data from the 3D environment, such as Simulation 3D Camera blocks, Priority must be set to 1 so the 3D environment can prepare the data before these blocks receive it.

For more information about execution order, see How Unreal Engine Simulation for Automated Driving Works.

Examples

Parameters

expand all

Scene

Scene Selection

Source of the scene in which to simulate, specified as one of the options in the table.

OptionDescription
Default Scenes

Simulate in one of the default, prebuilt scenes specified in the Scene name parameter.

RoadRunner

Simulate in a RoadRunner scene. To import the RoadRunner scene, specify the corresponding file in the Project parameter.

You can use these file formats.

  • Filmbox (.fbx) file.

  • Universal Scene Description (.usd, .usdc, and .usda) file.

  • RoadRunner scene or scenario (.rrscene or .rrscenario) files.

Unreal Executable

Simulate in a scene that is part of an Unreal Engine executable file. Specify the executable file in the Project name parameter. Specify the scene in the Scene parameter.

Select this option to simulate in custom scenes that have been packaged into an executable for faster simulation.

Unreal Editor

Simulate in a scene that is part of an Unreal Engine project (.uproject) file and is open in the Unreal® Editor. Specify the project file in the Project parameter.

Select this option when developing custom scenes. By clicking Open Unreal Editor, you can co-simulate within Simulink and the Unreal Editor and modify your scenes based on the simulation results.

Specify name of the prebuilt 3D scene in which to simulate. This parameter lists the default scenes and currently available scenes. You can also install additional scenes on demand. Once the scenes are installed, the Scene name parameter list is populated with all available scene names. For details about a scene, see its listed corresponding reference page.

These are the default scene options.

These are the scenes that you can install. For more information about other scenes, see 3D Scenes for Simulation in Unreal Engine Environment.

To install a new scene:

  1. Click Install.

  2. In the Add-on installer dialog box, select the scenes you want to install.

  3. To download and install the scenes, click Next and follow the prompts. MATLAB® restarts after installing the scenes.

After installation, you can select the new scenes from the Scene name parameter list.

The Automated Driving Toolbox Interface for Unreal Engine Projects contains customizable versions of these scenes. For details about customizing scenes, see Customize Unreal Engine Scenes for Automated Driving.

Dependencies

To enable this parameter, set Scene source to Default Scenes.

Name of the Unreal Engine executable file, specified as a valid executable project file name. You can either browse for the file or specify the full path to the project file, using backslashes. To specify a scene from this file to simulate in, use the Scene parameter.

By default, Project name is set to VehicleSimulation.exe, which is on the MATLAB search path.

Note

If you select a custom Unreal executable file built with a version of Unreal Engine that is not compatible with the current version of MATLAB, you receive one of these error messages:

  • "Incompatible version of 3D Simulation engine: Undefined": For Unreal executable built for a MATLAB release prior to R2023b

  • "Incompatible version of 3D Simulation engine: 23.2.0": For Unreal executable built for MATLAB R2023b or later

To resolve these errors, you must migrate the Unreal project and rebuild the executable with the latest support package installed. For more information, see How Unreal Engine Simulation for Automated Driving Works.

Example: C:\Local\WindowsNoEditor\AutoVrtlEnv.exe

Dependencies

To enable this parameter, set Scene source to Unreal Executable.

Specify an ASAM OpenDRIVE file. Select the block parameter Select ASAM OpenDRIVE file to specify an ASAM OpenDRIVE file. You will need an ASAM OpenDRIVE file if you want to perform any lane detection applications with custom scenes using the Simulation 3D Vision Detection Generator block.

Dependencies

This parameter is available when you set Scene Source is set to either Unreal Executable or Unreal Engine.

Data Types: Boolean

Name of a scene from the executable file specified by the Project name parameter, specified as a path to a valid scene name.

When you package scenes from an Unreal Engine project into an executable file, the Unreal Editor saves the scenes to an internal folder within the executable file. This folder is located at the path /Game/Maps. Therefore, you must prepend /Game/Maps to the scene name. You must specify this path using forward slashes. For the file name, do not specify the .umap extension. For example, if the scene from the executable in which you want to simulate is named myScene.umap, specify Scene as /Game/Maps/myScene.

Alternatively, you can browse for the scene in the corresponding Unreal Engine project. These scenes are typically saved to the Content/Maps subfolder of the project. This subfolder contains all the scenes in your project. The scenes have the extension .umap. Select one of the scenes that you packaged into the executable file specified by the Project name parameter. Use backward slashes and specify the .umap extension for the scene.

By default, Scene is set to /Game/Maps/HwStrght, which is a scene from the default VehicleSimulation.exe executable file specified by the Project name parameter. This scene corresponds to the prebuilt Straight Road scene.

Example: /Game/Maps/scene1

Example: C:\Local\myProject\Content\Maps\scene1.umap

Dependencies

To enable this parameter, set Scene source to Unreal Executable.

Name of the Unreal Engine project file or RoadRunner file, specified as a valid project file name. You can either browse for the file or specify the full path to the file, using backslashes. The file name must contain no spaces.

To simulate scenes from Unreal Engine project file in the Unreal Editor, click Open Unreal Editor. If you have an Unreal Editor session open already, then this button is disabled.

To run the simulation, in Simulink, click Run. Before you click Play in the Unreal Editor, wait until the Diagnostic Viewer window displays this confirmation message:

In the Simulation 3D Scene Configuration block, you set the scene source to 'Unreal Editor'.
In Unreal Editor, select 'Play' to view the scene.
This message confirms that Simulink has instantiated the scene actors, including the vehicles and cameras, in the Unreal Engine 3D environment. If you click Play before the Diagnostic Viewer window displays this confirmation message, Simulink might not instantiate the actors in the Unreal Editor.

To simulate a RoadRunner scene, you can import files in Filmbox (.fbx), Universal Scene Description (USD), RoadRunner scene (.rrscene), or RoadRunner scenario (.rrscenario) formats.

  • To simulate scenes in Filmbox (.fbx) format, browse for the folder containing the exported RoadRunner scene files and specify the .fbx file. You can export a RoadRunner scene using the option CARLA Filmbox in Export Using CARLA Filmbox (RoadRunner). This option exports these three files to a folder:

    • Filmbox (.fbx) file

    • ASAM OpenDrive (.xodr) file

    • XML (.rrdata.xml) file

  • To simulate scenes in Universal Scene Description (USD) format, browse for the folder containing the exported RoadRunner scene files, and select the .usd, .usdc, or .usda files. The actors imported from USD files are not compatible with collision detection. To export a RoadRunner scene in USD format, see Export to USD (RoadRunner).

  • To simulate scenes in RoadRunner scene or scenario (.rrscene or .rrscenario) formats, browse for the folder containing the RoadRunner files, and select the corresponding file. Before simulation, you must configure RoadRunner integration with MATLAB using the roadrunnerSetup (RoadRunner) function.

    • Enter the roadrunnerSetup function in the MATLAB Command Window.

    • The RoadRunner Setup dialog box opens.

    • Specify the RoadRunner Project Folder and RoadRunner Installation Folder locations.

For more information on exporting and simulating RoadRunner scenes, see Simulate in RoadRunner Scene (Simulink 3D Animation).

Tip

Semantic segmentation in Simulation 3D Camera and Simulation 3D Lidar uses the XML (.rrdata.xml) file. The ASAM OpenDRIVE (.xodr) file provides object data and lane ground truth data for the Simulation 3D Vision Detection Generator to generate detections. When you specify the Filmbox (.fbx) or Universal Scene Description (USD) file as the Project parameter, check that the XML (.rrdata.xml) and ASAM OpenDRIVE (.xodr) files are in the same folder.

Note

USD and RoadRunner scene or scenario (.rrscene or .rrscenario) file import are not supported on Linux®.

Dependencies

To enable this parameter, set Scene source to Unreal Editor or RoadRunner.

Scene Parameters

Configure the placement of the virtual camera to set the viewpoint that displays the scene during simulation. The Scene view parameter list is populated with all the Name parameter values of the vehicle and actor blocks in your model, along with any additional custom viewpoints you have created. If you add a Simulation 3D Scene Configuration block to your model, the virtual camera remains positioned at the scene origin. To reposition the camera to a custom viewpoint or to follow a vehicle, or actor, update this parameter.

The table lists the Scene view parameter options if your model contains no vehicle blocks, actor blocks, or custom viewpoints.

OptionDescription
Custom
  • Create a custom viewpoint. This option enables these parameters.

    • Name

    • Translation

    • Rotation

  • Click Save Viewpoint to create the viewpoint.

  • View the scene in free camera mode. The camera movement uses the world coordinate system.

Scene Origin
  • Set the viewpoint at the scene origin.

  • View the scene in free camera mode. The camera movement uses the world coordinate system.

The table lists the additional options if your model contains vehicle blocks, actor blocks, or custom viewpoints.

OptionDescription
Vehicle name
  • Attach the virtual camera to the selected vehicle block in your model.

  • You can only change the location of the camera around the vehicle.

sim3d actor name
  • Attach the virtual camera to the selected Simulation 3D Actor block in your model.

  • This option enables these parameters to set the location of the camera relative to the actor origin.

    • Viewer relative translation [X, Y, Z] (m)

    • Viewer relative rotation [Roll, Pitch, Yaw] (deg)

Viewpoint name
  • Set the viewpoint to the selected viewpoint name. This option also enables these parameters.

    • Name

    • Translation

    • Rotation

  • Click Save Viewpoint to update the viewpoint.

  • Click Delete Viewpoint to remove it.

  • View the scene in free camera mode. The camera movement uses the world coordinate system.

Scene Controls

When Scene view is set to Scene Origin or Custom, you can change the location of the camera to navigate in the scene during simulation using keyboard and mouse control. You can also change the camera location when the simulation is paused.

To navigate in the 3D environment, use these keyboard shortcuts.

Keyboard ShortcutCamera Control

W

Move forward.

Shift+W

Move faster in the forward direction.

S

Move backward.

Shift+S

Move faster in reverse direction.

A

Move left.

Shift+A

Move faster toward left.

D

Move right.

Shift+D

Move faster toward right.

E

Move up.

Shift+E

Move faster in the upward direction.

Q

Move down.

Shift+Q

Move faster in the downward direction.

Mouse scroll wheel

Control the camera distance from the cursor point.

Shift+mouse scroll wheel

Camera moves faster.

Mouse right-click and drag

Orbit around the cursor point.

O

Attach camera to actor, including vehicle, pedestrian or bicyclist under the cursor point.

Mouse left-click and drag

Orbit around the actor after camera attaches to the actor.

P

Detach camera from the actor.

L

Record the current viewpoint and display Location saved on the scene.

1 to 9

Access the stored viewpoints, if available.

Tab

Cycle the view between all vehicles in the scene and the viewpoint at the start of the simulation, in the forward direction.

Shift+Tab

Cycle the view between all vehicles in the scene and the viewpoint at the start of the simulation, in the reverse direction.

I

Toggle the display of keyboard shortcuts on the screen. Press once to show and again to hide.

Vehicle Views

When Scene view is set to a vehicle name, during simulation, you can change the location of the camera around the vehicle. You can also set the view to a vehicle during simulation by pressing Tab.

To smoothly change the camera views, use these keyboard shortcuts.

Keyboard ShortcutCamera View

1

Back left

A diagram shows numbered key commands corresponding to camera views

 View Animated GIF

2

Back

3

Back right

4

Left

5

Internal

6

Right

7

Front left

8

Front

9

Front right

0

Overhead

For additional camera controls, use these keyboard shortcuts.

Keyboard ShortcutCamera Control
Tab

Cycle the view between all vehicles in the scene.

 View Animated GIF

Mouse scroll wheel

Control the camera distance from the vehicle.

 View Animated GIF

L

Toggle a camera lag effect on or off. When you enable the lag effect, the camera view includes:

  • Position lag, based on the vehicle translational acceleration

  • Rotation lag, based on the vehicle rotational velocity

This lag improves visualization of overall vehicle acceleration and rotation.

 View Animated GIF

F

Toggle the free camera mode on or off. When you enable the free camera mode, you can use the mouse to change the pitch and yaw of the camera. This mode allows you to orbit the camera around the vehicle.

 View Animated GIF

Since R2025a

Specify the name of the custom viewpoint as a character array or string scalar.

Example: View1

Dependencies

To enable this parameter, set Scene view to Custom.

Data Types: char | string

Since R2025a

Specify the viewpoint translation (x,y,z) as a real 1-by-3 vector, in m.

Dependencies

To enable this parameter, set Scene view to Custom.

Data Types: double

Since R2025a

Specify the viewpoint rotation (roll, pitch, yaw) as a real 1-by-3 vector, in deg.

Dependencies

To enable this parameter, set Scene view to Custom.

Data Types: double

Since R2025a

Specify the viewpoint translation (x,y,z) relative to sim3d actor origin as a real 1-by-3 vector, in m.

Dependencies

To enable this parameter, set Scene view to the sim3d actor name.

Data Types: double

Since R2025a

Specify the viewpoint rotation (roll, pitch, yaw) relative to sim3d actor origin as a real 1-by-3 vector, in deg.

Dependencies

To enable this parameter, set Scene view to the sim3d actor name.

Data Types: double

Sample time, Ts, of the visualization engine, specified as a real positive scalar. Units are in seconds.

The graphics frame rate of the visualization engine is the inverse of the sample time. For example, if Sample time is 1/60, then the visualization engine solver tries to achieve a frame rate of 60 frames per second. However, the real-time graphics frame rate is often lower due to factors such as graphics card performance and model complexity.

By default, blocks that receive data from the visualization engine inherit this sample rate.

Select whether to run simulations in the 3D visualization environment without visualizing the results, that is, in headless mode.

Consider running in headless mode in these cases:

  • You want to run multiple 3D simulations in parallel to test models in different Unreal Engine scenarios.

  • You want to capture sensor data to analyze in MATLAB but do not need to watch the visualization.

Dependencies

To enable this parameter, set Scene source to Default Scenes or Unreal Executable.

Weather

Select whether to control the scene weather and sun position during simulation. Use the enabled parameters to change the sun position, clouds, fog, rain, and snow.

This table summarizes sun position settings for specific times of day.

Time of DaySettingsUnreal Editor Environment

Midnight

Sun altitude: -90

Sun azimuth: 180

Road at midnight

Sunrise in the north

Sun altitude: 0

Sun azimuth: 180

Road at sunrise

Noon

Sun altitude: 90

Sun azimuth: 180

Road at noon

This table summarizes settings for specific cloud conditions.

Cloud ConditionSettingsUnreal Editor Environment

Clear

Cloud opacity: 0

Road with clear skies

Heavy

Cloud opacity: 85

Road with cloudy skies

Heavy

Enable Volumetric clouds: Selected

Cloud Coverage: 50

Cloud layer altitude: 6

Road with volumetric clouds

This table summarizes settings for specific fog conditions.

Fog ConditionSettingsUnreal Editor Environment

None

Fog density: 0

Road with no fog

Heavy

Fog density: 100

Road with heavy fog

This table summarizes settings for specific rain conditions.

Rain ConditionSettingsUnreal Editor Environment

Light

Cloud opacity: 10

Rain density: 25

City scene with light rain

Heavy

Cloud opacity: 10

Rain density: 80

City scene with heavy rain

This table summarizes settings for specific snow conditions.

Snow ConditionSettingsUnreal Editor Environment
HeavySnow density: 50

Road scene with heavy snow

Sun

Azimuth angle in the horizontal plane measured from the south to the horizontal projection of the sun rays, in deg.

Diagram of sun altitude angle (vertical arrow) and sun azimuth angle (horizontal arrow

Use the Sun altitude and Sun azimuth parameters to control the time of day in the scene. For example, to specify sunrise in the north, set Sun altitude to 0 deg and Sun azimuth to 180 deg.

Dependencies

To enable this parameter, select Override scene weather.

Altitude angle in a vertical plane between the sun's rays and the horizontal projection of the rays, in deg.

Diagram of sun altitude angle (vertical arrow) and sun azimuth angle (horizontal arrow)

Use the Sun altitude and Sun azimuth parameters to control the time of day in the scene. For example, to specify sunrise in the north, set Sun altitude to 0 deg and Sun azimuth to 180 deg.

Dependencies

To enable this parameter, select Override scene weather.

Select this check box to enable geospatial sun. Enabling geospatial sun is useful to simulate conditions near the poles or at locations with disproportionate lengths of day versus night.

Dependencies

To enable this parameter, select Override scene weather.

Latitude of geolocation on earth, specified as a scalar, in deg.

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Longitude of geolocation on earth, specified as a scalar, in deg.

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Date, specified as an integer in the format YYYY-MM-DD.

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Time, specified as an integer in the format HH:MM:SS.

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Time zone specifies the number of hours offset from the Coordinated Universal Time (UTC) or Greenwich Mean Time (GMT).

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Select this check box to enable daylight saving time.

Dependencies

To enable this parameter, select Override scene weather and Enable geospatial sun.

Cloud

Parameter that corresponds to the Unreal Editor Cloud Speed global actor target value. The clouds move from west to east for positive values and east to west for negative values.

Cloud Opacity and Cloud Speed settings in Unreal Editor

Use the Cloud opacity and Cloud speed parameters to control clouds in the scene.

Dependencies

To enable this parameter, select Override scene weather.

Parameter that corresponds to the Unreal Editor Cloud Opacity global actor target value, in percent. Zero is a cloudless scene.

Cloud Opacity and Cloud Speed settings in Unreal Editor

Use the Cloud opacity and Cloud speed parameters to control clouds in the scene.

Dependencies

To enable this parameter, select Override scene weather.

Select this check box to enable volumetric clouds.

Dependencies

To enable this parameter, select Override scene weather.

Parameter that corresponds to the Unreal Editor Cloud Density global actor target value, in percent.

Cloud coverage settings in Unreal Editor

Use the Cloud coverage parameter to control clouds in the scene.

Dependencies

To enable this parameter, select Override scene weather and Enable volumetric clouds.

Parameter that corresponds to the Unreal Editor Layer Bottom Altitude global actor target value, in km.

Cloud altitude setting in Unreal Editor

Dependencies

To enable this parameter, select Override scene weather and Enable volumetric clouds.

Fog

Parameter that corresponds to the Unreal Editor Set Fog Density and Set Start Distance target values, in percent.

Set Fog Density setting in Unreal Editor

Dependencies

To enable this parameter, select Override scene weather.

Rain

Parameter corresponding to the Unreal Editor local actor that controls rain density, wetness, rain puddles, and ripples, in percent.

Unreal Editor settings to control rain density. The Get Components by Class on the left activates or deactivates the rain density settings. The rain effects on the right control settings such as wetness, rain puddles, and ripples.

Use the Cloud opacity and Rain density parameters to control rain in the scene.

Dependencies

To enable this parameter, select Override scene weather.

Select this check box to enable raindrops on the camera lens.

Cloud altitude setting in Unreal Editor

Dependencies

To enable this parameter, select Override scene weather.

Snow

This parameter corresponds to the Unreal Editor global actor that controls snow density, in percent.

Cloud altitude setting in Unreal Editor

Dependencies

To enable this parameter, select Override scene weather.

More About

expand all

Version History

Introduced in R2019b

expand all