© Square Enix © Goodbye Kansas


Table of Contents

This page provides information on the Anti-Aliasing options in the Sampler tab of the V-Ray Renderer.


Overview


In V-Ray, an image sampler refers to an algorithm for calculating a pixel's color based on the colors within and around it.

Each pixel in a rendering can have only one color. To get the color of a pixel, V-Ray calculates it based on the object's material, direct light striking the object, and indirect lighting in the scene. But within a single pixel there might be multiple colors, which may come from multiple objects whose edges intersect at the same pixel, or even difference in brightness on the same object due to changes in object shape or falloff and/or shadowing of light sources.

To determine the right color for such a pixel, V-Ray looks at (or samples) colors from different parts of the pixel itself as well as the pixels around it. This process is called image sampling. V-Ray includes two main image samplers, each with its own approach to sampling and its own parameters: Progressive and Bucket.



Image courtesy of Tuna Unalan


Multiple colors within a single pixel. What color should the pixel be? 





What is Anti-Aliasing?


One of the functions of image sampling is anti-aliasing, which is the reduction of jagged edges in a rendering. The following example shows the basic difference between an image with anti-aliasing, and one without. 

If only one sample is taken for each of the pixels around the edge of the sphere, the choice of pixel color is limited to the dark gray at the edge of the object, or the (white) background. Using one of these colors (i.e. taking only one sample) makes the image look jagged. This is the equivalent of no anti-aliasing at all.

If two or more samples are taken in each pixel, the colors are averaged, and pixels at the edge of the object end up being a color in between the dark gray of the sphere and the background. These in-between colors make the object appear smoother in the final rendering.



1
24


Anti-Aliasing


This section covers common parameters for all sampler types. For parameters that are specific to each sampler, see the following sampler sections below.

Type – Specifies the image sampler type. Specific parameters for the selected type appear at the bottom of this rollout.

Progressive – Progressively samples the entire image. See the Progressive Sampler for additional parameters.
Bucket – Takes a variable number of samples per pixel depending on the difference in the intensity of the pixels. See the Bucket Sampler section for additional parameters. 

Min. Shading Rate – Controls the number of rays shot for AA versus rays for other effects like glossy reflections, GI, area shadows, etc. Higher values mean that less time is spent on AA and more effort is put in the sampling of shading effects.

Render Mask – Enables the render mask feature. The render mask allows you to define which pixels of the image are calculated. The rest of the pixels are left intact. This feature works best with the V-Ray frame buffer and the Bucket image sampler. The following types are available:

Disable – The render mask is not used.
Texture – Uses a black & white texture to limit rendering to the white areas of the texture only. You can also use animated texture sequences by specifying an Image File VOP using the op: synthax (e.g. /mat/imageFile). Note that the Type of Image File VOP's UV must be set to Environment, and the Mapping Type to Screen
Object – Only the specified objects are rendered.
Object ID – Only objects with the specified object IDs are rendered. You can list more than one object ID as a space-separated list. To add IDs to the Geometry nodes, add V-Ray Object Properties using the V-Ray menu.

For more information, see the Render Mask example below.

Clear Mask on Render Stat – Available when the Render Mask is enabled. When disabled, the masked region is overlaid on top of the previous image in the VFB. This can be used for draft renders or fast shader previews provided that the camera does not move. Note: When rendering an animation, the image clearing is forced on.

Object IDs – Specifies a list of object IDs to be used for the render mask, when the Render mask is set to Object ID.

AA Filter Type – Specifies the filter type to be used for anti-aliasing. V-Ray supplies eight types of Anti-aliasing filters: Box, Area, Triangle, Lanczos, Sinc, Catmull-Rom, Gaussian and Cook Variable. Each has advantages and disadvantages, which make them useful for different tasks. For more information, see the Anti-aliasing Filters example and the Anti-aliasing Filters and Moire Effects example below.

Size – Determines the size of the filter in pixels. Higher values yield blurrier results. For more information, see the Anti-aliasing Filters example and the Anti-aliasing Filters and Moire Effects example below.






Example: Anti-aliasing Filters


Here is an example briefly demonstrating the effect of different anti-aliasing filters on the final result.

Note that rendering with a particular filter is not the same as rendering without a filter and then blurring the image in a post-processing program like Adobe Photoshop. Filters are applied on a sub-pixel level, over the individual sub-pixel samples. Therefore, applying the filter at render time produces a much more accurate and subtle result than applying it as a post effect. The zoomed in images below have been zoomed in and cropped 300%.



Filtering is off

Lanczos filter, size 2.5

Triangle filter

Sinc filter, size 2.5

Box filter, size 2.5

Area filter, size 2.5

Catmull-Rom filter

Cook Variable filter, size 2.5

Caussian filter, size 2.5

Drag the slider to change the filter type.





Example: Anti-aliasing Filters and Moire Effects


This example demonstrates the effect anti-aliasing filters have on moire effects in your images. Sharpening filters may enhance moire effects, even if your image sampling rate is very high. Blurring filters reduce moire effects.

Note that moire effects are not necessarily a result of poor image sampling. In general, moire effects appear simply because the image is discretized into square pixels. As such, they are inherent to digital images. The effect can be reduced through the usage of different anti-aliasing filters, but is not completely avoidable.

The scene is very simple: a sphere with a very fine checker map applied. The images were rendered with a very high sampling rate (15 subdivs, or 225 rays/pixel). This is enough to produce quite an accurate approximation to the pixel values. Note that the image looks quite different depending on the filter:


No Filter

Box filter

Area filter, size 1.5

Area filter, size 4.0

Triangle filter, size 1.5

Lanczos filter

Catmull-Rom filter

Gaussian filter, size 1.5

Gaussian filter, size 6.0

Drag the slider to change the filter type.




Example: Render Mask



The original image


The same image, only objects with chrome material were re-rendered





The actual render mask image - RGB channels


The actual render mask image - Alpha channel



Progressive Sampler


This section provides information specific to the Progressive Sampler Type. The Progressive sampler renders the entire image progressively in passes.

The advantage of this sampler is that you can see an image very quickly, and then let it refine for as long as necessary as additional passes are being computed. This is contrast to the bucket-based image samplers, where the image is not complete until the final bucket is done.

A disadvantage is that more data needs to be kept in memory, especially when working with render elements. Also, when using distributed rendering, because of the continuous refinement, frequent communication between the client machine and the render servers is required, which may reduce the CPU utilization on the render servers. This effect can be controlled to some extent using the Ray bundle size parameter.

Min Subdivs – Controls the minimum number of samples that each pixel in the image receives. The actual number of the samples is the square of the subdivs. Note: Not available when using a GPU-based Production engine.

Max Subdivs – Controls the maximum number of samples that each pixel in the image receives. The actual number of the samples is the square of the subdivs. If zero, the number of samples is not limited.

Noise Threshold – The desired noise level in the image. If this is 0.0, the entire image is sampled uniformly until either the Max. subdivs value is reached or the Render time limit is reached.

Max. Render Time (min) – The maximum render time in minutes. When this number of minutes is reached, the renderer stops. This is the render time for the whole frame; it includes any GI prepasses like light cache, irradiance map, etc. If this is 0.0, the render is not limited in time.

Ray Bundle Size (CPU) – Useful for distributed rendering to control the size of the chunk of work that is handed to each machine. When using distributed rendering, higher values may help to utilize CPUs on the render servers better.

Ray Bundle Size (GPU) – Controls the number of samples to transfer over the network for RT-GPU. Available when using RTX rendering. 

Rays Per Pixel – Controls the number of samples per pixel for RT-GPU. Available when using GPU/RTX rendering.

Avoid using the Progressive sampler with sharpening image filters (Catmull-Rom, Mitchell-Netravali) as this may slow down the rendering - additional image samples are required to resolve sharpening filters properly. V-Ray prints a warning in this case in the V-Ray messages window.






Example: Stages of Rendering with the Progressive Sampler



Image after 1 pass

Image after 16 passes

Image after 64 passes

Image after 256 passes

1 pass
256 passes



 

Bucket Sampler


This section covers information specific to the Bucket Sampler Type.

This sampler makes a variable number of samples per pixel based on the difference in intensity between the pixel and its neighbors.

This is the preferred sampler for images with lots of small details (like Procedural Fur for example) and/or blurry effects (DOF, motion blur, glossy reflections, etc.).

The diagram above shows visually the way V-Ray is placing samples when using the Bucket sampler. The black squares represent the pixels of the image while the dots represent the individual samples. In the first pass V-Ray always places the minimum number of samples determined by the Min. subdivs parameter. Then the color of the samples is compared and more are added where needed in the following passes.


 



Lock Subdivs – Sets a fixed number of samples taken for each pixel.

Min Subdivs – Determines the initial (minimum) number of samples taken for each pixel. You will rarely need to set this to more than 1, unless you have very thin lines that are not captured correctly, or fast moving objects when using motion blur. The actual number of samples is the square of this number (e.g. 4 subdivs produce 16 samples per pixel).

Max Subdivs – Determines the maximum number of samples for a pixel. The actual maximum number of samples is the square of this number (e.g. 4 subdivs produces a maximum of 16 samples). Note that V-Ray may take less than the maximum number of samples, if the difference in intensity of the neighboring pixels is small enough.

Noise Threshold – The threshold that is used to determine if a pixel needs more samples.

Adaptivity Clamp – Specifies an intensity limit for the adaptive bucket to avoid excessive sampling of overexposed areas. Lower values mean a lower limit and potentially noisy overexposed areas. Higher values produce more samples in overexposed areas.



Textures


This rollout is active only when rendering on GPU/RTX.

Resize Textures – Determines how textures' resolution/size are handled to help optimize memory usage. The possible values are:

Full Size – Textures are loaded at their original size.
Resize – Adjusts the size of high-resolution textures to a smaller resolution to optimize render performance.
Mipmapping – Instead of loading all the texture files at their default resolution (original or resized), V-Ray loads the textures as needed and automatically create mip-map tiles for them (regardless of their texture type). As a result, the GPU memory consumption could be decreased; textures that are not visible are not loaded, and textures that are further away from the camera are loaded with a lower resolution. During the texture-detection process, V-Ray GPU renders slower. Once it detects that all textures are loaded, it switches automatically to the traditional, faster mode, and a message about modes changing displays in the V-Ray log. This option is only available in the Production Rendering Mode.
Compressed – Textures are loaded with compression to decrease GPU memory consumption. This texture mode sacrifices some texture quality to make the texture smaller (roughly ~75% reduction in memory usage). As a result, you need much less memory for textures enabling renders of bigger scenes. Not all textures are compressed using this option and exceptions are made based on the bitmap usage:

    • If a bitmap is used for both normal/bump and color maps, as compression for normal maps is generally not good for color maps, and vice versa;
    • Bitmaps used for displacement;
    • Bitmaps used for lens effects.

Compressed mode is supported on Windows and Linux only. On Apple devices the rendering will fallback to Full Size.

Size – When GPU Resize textures is enabled, this value specifies the resolution to which the textures are resized.

Format – The amount of bits per channel used to store the material texture information into memory. You can choose between 8 bit16 bit and 32 bit. This does not affect textures used for lights and displacement.



Post Effects


Post Effect Rate – The regularity of updates during the progressive rendering; roughly the percentage of the time effects like denoising and/or lens effects are allowed to take compared to the frame render time. Zero disables updates during the progressive rendering, while larger values cause the effects to be updated more frequently; 100 causes updates as often as possible. Values ranging from 5 to 10 are usually sufficient.



Notes


  • A note on RAM usage: image samplers require substantial amount of RAM to store information about each bucket. Using large bucket sizes may take a lot of RAM.