Rendering with mPath

mPath is a ground-up redesign of the Modo renderer, with dramatic reduction in controls, versatile hybrid compute capabilities, and granular refinement features. It offers many improvements over the Default renderer, including GPU acceleration for Ray Tracing when NVIDIA OptiX is selected as the Ray Tracing Engine.

Note:  Multiple GPUs are not currently supported by the mPath renderer.

If you have scenes with many lights and you want to render out separate light passes, mPath is a better option for you over the Default renderer as each light can be rendered to a separate render output as part of one single render process. This dramatically reduces render times and improves flexibility in compositing workflows.

Note:  See Render Outputs Per Light for more information.

The Final Color output for this render, rendered using mPath.

The Light Path Expression output generated for the light tagged "lumi" in the light's LPE Label.

The Light Path Expression output generated for the light tagged "lumiL" in the light's LPE Label.

The Light Path Expression output generated for the light tagged "lumiR" in the light's LPE Label.

The mPath rendering workflow is also best utilized for speed improvements in Ray Tracing and Shadow Ray Tracing, and for effects like depth of field. Shading results are also more accurate with mPath, for example in Fresnel and refractive materials.

The following images demonstrate different ray depth values. Improved contact shadows, and improved reflections between close reflective components occur as Reflection Depth increases. There is increased accuracy with transparent components as Refraction Depth is increased. Accurate refractions require high depth values.

Rendering Scenes Using mPath

1.   In the Shader Tree, select your Render item.

This opens this render item's Properties.

2.   In the Frame sub-tab, set Renderer to mPath.
3.   In the Settings sub-tab, select your Ray Tracing Engine.

Tip:  mPath is a hybrid renderer and can take advantage of the CPU and GPU in tandem. The default Foundry SSE (CPU) setting uses only the CPU for raycasting. To use the GPU for raycasting, select NVIDIA OptiX (GPU), or to use improved performance for CPU raycasting, select Intel Embree (CPU).

4.   Adjust the mPath settings in the Render Item's Settings sub-tab.

For more information on what the different options are, see Render Item: mPath Renderer Settings.

Note:  mPath automatically uses Environment Importance Sampling if an active texture layer such as an HDR image map is affecting the environment. See Environment Importance Sampling to learn more.

5.   Render your scene by pressing F9 or along the menubar, clicking Render > Render.

The render starts and the Render window opens.

Note:  To decrease noise in the rendered image, we recommend using a Denoiser. See Denoising mPath Renders for more information.

Note:  Press P during an mPath render to pause to rendering. The current render can then be saved as an image.

Interactive mPath Renders

Modo's mPath renderer has an interactive mode, which allows you to pan, zoom, and rotate the camera in the Render viewport without adjusting the camera in the scene. In interactive mode, mPath constantly renders the scene to update the output when the camera position changes.

To start an interactive mPath render, you can:

press Alt+F9,

navigate to the Render menu and select mPath QuickCam, or

click and hold the Render button in the Render viewport and select mPath QuickCam.

Render iterations continue until you press Abort in the Render viewport, Esc on the keyboard, or P to pause the render.

Tip:  You don't need to select mPath from the Render dropdown to start an interactive render. If you have the Default renderer active, Modo activates mPath for the interactive render and then switches back to Default automatically.

In interactive mode, you can:

pan the camera by left-clicking and dragging in the viewport,

Panning from left to right.

dolly in and out by scrolling the mouse wheel, and

Dollying in.

rotate the camera by holding Alt and left-clicking and dragging in the viewport.

Rotating left to right.

Denoising mPath Renders

Rendering with mPath can produce noisy results due to the way path tracing resolves an image. In path tracing, the render direction of each path relies on random numbers which are different for each pixel. This results in nearby pixels having differing results from one another, creating a noisy looking image. As more samples are added to each pixel, eventually the image becomes less noisy but this can take a long time.

Using a denoiser with your mPath renders means the path tracing process can be completed before all pixels are fully converged, but you still end up with a smooth, high-quality image. This saves you a lot of time without compromising on quality. You must select a denoiser from the Denoising property inside your render output if you want to denoise your renders.

Tip:  See Denoising for more information on the available denoisers.

To denoise your mPath renders before rendering:

1.   Select your Render Output item in the Shading list, for example the Final Color Output.

For more information, see Render Outputs and Basic Render Outputs.

2.   In the Render Output Properties, select a denoiser from Denoising.

If a denoiser is not available on your system, Modo displays a warning icon next to it. You can still select it, allowing you to set up the scene for rendering on a different system, but a warning dialog is produced when the render is started on an unsupported system.

3.   In the Render Output Properties, enable Denoise Per Iteration if you are using Render Outputs per Light.

See Render Outputs Per Light for more information.

4.   Render your scene by pressing F9 or along the menubar, clicking Render > Render.

The render starts and the Render window opens. You can verify the denoiser in the Denoising section in the Statistics panel of the Render window.

Render Outputs Per Light

With Modo's Default renderer, you have to create separate renders for each light. mPath rendering allows you to create individual light outputs within a single render by giving you the ability to add Light Path Expressions.

Tip:  If you are using a Denoiser with your mPath render, enable Denoise Per Iteration in the render output settings to ensure each light pass is denoised correctly. See Denoising for more information.

Light Path Expressions

Light Path Expressions are character strings that can be used to restrict which kinds of light paths contribute radiance to a particular render output image. A path contribution is only added to a render output if its sequence of events (the vertices of the path) matches the pattern specified by the render output's Light Path Expression string.

All paths start at the camera and end at something that emits light, which can be an emissive surface, a volumetric effect, a light source, or the environment. In between the starting and ending events, zero or more scattering events can occur, in which light bounces off or passes through a surface.

To add a Light Path Expression:

Tip:  To use Light Path Expressions, make sure mPath is selected as your Renderer in the Render item Properties.

1.   Click Render > Add Per-Light Render Outputs.

A Light Path Expressions Output is added to your Shader Tree for each individual light present in the scene, using the naming convention LPE: C.*'<name of light / LPE label>'.

Tip:  Use the LPE Label inside the item Properties to specify a label to be used on that item for Light Path Expressions. LPE labels can be added to lights, materials, environments, and volumetric surfaces.

2.   Select the Light Path Expressions Output in the Shader Tree.
3.   Enter your Light Path Expressions in the Light Path Expression field in the Properties.

Use the following examples to specify your Light Path Expression, or use one of the presets from the Light Path Expression dropdown.

Starting Event Types

C signifies the camera. Since all paths begin at the camera, all valid Light Path Expressions must begin with C.

Scattering Event Types

Syntax Usage


Diffuse reflection event.


Specular reflection event.


Diffuse transmission event, which includes subsurface scattering and translucency.


Specular transmission event, which includes refraction and dissolve.


A reflection event, where the path continues on the same side as the surface normal. It can be either Diffuse (<RD>) or Specular (<RS>).


A reflection event, where the path continues on the opposite side from the surface normal. It can be either Diffuse (<TD>) or Specular (<TS>).


A diffuse scattering event. It can be either Reflection or Transmission (<RD> or <TD>).


A specular scattering event. It can be either Reflection or Transmission (<RD> or <TD>).

Ending Event Types

Syntax Usage


Object. An emissive object (a surface with a nonzero Luminous Amount and Luminous Color).


Volumetrics. Currently in Modo it is only used for light added by fog.


Light. A direct light source.


Background. In Modo this means the light from the environment item.

Special Characters

Syntax Usage

. (period)

A wildcard that can match any event type.

* (asterisk)

Zero or more instances of the preceding event type. Currently in Modo '*' can only occur immediately after the wildcard '.', once per light path expression.

[ ]

An 'or' group, which can match any of the event types listed within the brackets.

' ' (single quotes)

A text label that can restrict the preceding event to one or more items that have been assigned the label appearing within the quotes. Currently, labels cannot appear within square brackets or in between the '.' and '*' characters.


Syntax Usage


All paths. This is equivalent to the Final Color render output.


Direct and indirect diffuse reflection.


Highlights (specular reflection of direct lights).


All shading resulting from direct lights having the label 'sun'.


All shading resulting from light from emissive objects or the background.


Caustics (light that has scattered from a specular to a diffuse surface).

Viewing Render Outputs Per Light

Once you have created a render using F9 or one of the render commands in the Render menu, you can switch between your different light outputs in the Render window Output dropdown.