For optimal execution of tasks in parallel, also known as load balancing, it is essential to subdivide the entire rendering operation into small tasks, which are called jobs in mental ray. Jobs may perform a wide variety of operations: tessellating a portion of a surface, loading a portion of a texture, casting a bundle of rays, rendering a section of the image, balancing a photon map, and many others.
mental ray is executing jobs on demand, managed by a dependency graph of jobs. For example, a job is executed only when another job accesses data generated by that job. The data generated by jobs enters a memory pool, traditionally called the geometry cache. This cache manages almost all data stored in memory by mental ray, including textures, photons, images, and more. Data can not only enter the cache but may also be deleted when memory fills up and the data has not been used for a while, and it is known that the source data is available or can be recreated at any time. This is handled by mental ray memory management.
Dynamic job execution and the geometry cache as the central hub of mental ray has several advantages:
In general, geometry caching has the effect of exploiting scene coherence very effectively. mental ray achieves significantly higher speed at noticeable memory usage reduction compared to previous generation. Unlike traditional geometry caching methods, this advantage is not limited to specific scenes; it works with all aspects of mental ray including ray tracing and global illumination. It works better if the scene does have a high degree of coherence, but advantages remain even for less-coherent scenes. For example, scenes that make extensive use of global illumination, which by definition is global and less coherent, may require a larger cache but will still benefit from its use.
The memory management system in mental ray allows efficient use of the memory resources available on the rendering machine, and provides the basis for the capability to render huge scenes on systems with limited memory. Any memory that is allocated in mental ray core and in shaders (using the memory shader interface functions) will be registered in the memory module together with other essential information. This permits to watch overall consumption and to react to progress and failure conditions during rendering.
The primary control to tune memory usage in mental ray is the memory limit. It is predefined on 32bit systems to about 1GB to work well in most existing systems, and unlimited on 64bit systems. It may be set to any other value, and even to "unlimited" in special cases. In the "unlimited" case, mental ray is fully depending on the operating system to provide memory, and starts to intervene only when the system fails to allocate. However, in this case, typically very little resources are left to perform clean-up procedures in reasonable time, and mental ray's attempt to survive the bottleneck and finish the current rendering may take a long time or fail anyway. Setting the limit too high has a similar effect. On the other hand, tuning down the limit can help to render a huge scene successfully, at the expense of reducing the performance noticeably (due to releasing and re-creating pieces of the scene). It is best practice to model scene elements in smaller pieces instead of creating huge concrete objects, and to utilize callback mechanisms like object placeholder and assemblies whenever possible, to benefit most from the memory management system.
The memory limit may be adjusted globally by a registry variable, or overridden for a specific rendering by a command line option.
Copyright © 1986-2010 by mental images GmbH