Jump to content

LuxCoreRender

From Wikipedia, the free encyclopedia
(Redirected from PBRT)
LuxCoreRender
Developer(s)Jean-Philippe Grimaldi, Jean-Francois Romang, David Bucciarelli, Ricardo Lipas Augusto, Asbjorn Heid and others.[1]
Initial releaseJune 24, 2008; 16 years ago (2008-06-24)
Stable release
2.6 / December 25, 2021; 2 years ago (2021-12-25)[2]
Repository
Written inC++, Python
Operating systemCross-platform
Type3D computer graphics
LicenseApache 2.0
Websitewww.luxcorerender.org

LuxCoreRender is a free and open-source physically based rendering software. It began as LuxRender in 2008 before changing its name to LuxCoreRender in 2017 as part of a project reboot.[3][4] The LuxCoreRender software runs on Linux, Mac OS X, and Windows.

Overview

[edit]

LuxCoreRender features a 3D renderer; it relies on other programs (3D modeling programs) to create the scenes to render, including the models, materials, lights and cameras. This content can then be exported from the application for rendering. For Luxrender, fully functional exporters are available for Blender, Daz Studio; partially functional ones are available for Cinema 4D, Maya, SketchUp and XSI.[5] Luxrender is also fully supported as a production renderer in 3DS Max.[6] For LuxCoreRender, Blender is supported through the BlendLuxCore plugin.[7] After opening the exported file, LuxCoreRender renders the scene. Various tweaks to post processing settings can be set via graphical user interface and the scene control file.[8] A significant feature of LuxCoreRender is that the user is able to change the balance of different lights while the image is still being processed.[9][10]

History

[edit]

LuxRender

[edit]

LuxCoreRender originally started as LuxRender in 2008. LuxRender was based on PBRT, a physically based ray-tracing program.[11] Although very capable and well-structured, PBRT focuses on academic use and was not easily usable by digital artists. As PBRT is licensed under the BSD License, it was possible to start a new program based on PBRT's source code. With the blessings of the original authors, a small group of programmers took this step in September 2007. The new program was named LuxRender and was to focus on artistic use. Since its initial stage, the program has attracted a small handful of various programmers around the world.[1]

On 24 June 2008, the first official release was announced, version 0.5.[12] This was the first release that is considered to be usable for the general public.

LuxCoreRender (LuxRender 2.x)

[edit]

The plan for LuxRender 2.0 was defined during the 2013 summer and one of the major components is a new engine based on the C++ and Python APIs. The old C API suffered from many limitations when it came to modern features like dynamic scene editing and interactive rendering, so it was decided to write a completely new API instead of improving the old one. LuxCore is the name of the new C++/Python API. It offers all the features shown by SLG (SmallLuxGPU),[13] including a dynamic camera, texture, material, and object editing, and more.

Why Lux(Core)Render v2.0?
Because LuxRender project was dying under the weight of a lot of old abandoned code. All active developers had the strong feeling a fresh start was required. The "Core" between "Lux" and "Render" is there to highlight the new project focus. However the "v2.0" is there to re-mark the continuity with 10 years of development and experience.

During the 2017 winter, LuxCoreRender 2.0 was defined as a LuxCore API focused render package, dropping any old code related to LuxRender 1.x. A new website, forum, wiki, Blender exported, etc. were developed in order mark a new fresh project restart.

Although the original LuxRender is a full spectral renderer, the new LuxCoreRender drops full spectral rendering in favor of simulating spectral dispersion when required.[14][15] However, this leads to some inaccuracies when rendering caustics in some circumstances.[16]

Features

[edit]
LuxRender 1.0 render of a modern classroom modeled in Blender

LuxCoreRender 2.5

[edit]

Features included in the LuxCoreRender 2.5 update include: [17]

  • Nvidia OptiX
  • Non Uniform Camera Bokeh
  • new Materials: Holdout and double sided
  • new textures: wireframe and distort
  • randomized tiling
  • new AOVs
  • 180° and 360° Stereo Cameras
  • improvements for the blender plugin

LuxCoreRender 2.4

[edit]

Features included in the LuxCoreRender 2.4 update include: [18]

  • Support for using more than 64 logical processors in Windows.
  • Support for CUDA rendering on NVIDIA graphics cards, with out-of-core capability.
  • The ability to create materials with thin-film interference.

LuxCoreRender 2.0–2.3

[edit]

Features included in the LuxCoreRender 2.0+ project reboot (current version) include:[19]

  • Microkernel pure-OpenCL "Path" render engine, supporting any number of GPUs and OpenCL-enabled CPUs concurrently.
  • Interactive viewport rendering, including real-time material and object manipulation.
  • Material node support.
  • Light groups, allowing the user to change the intensity and color of lamps during the rendering process.[10]
  • Embree accelerated BVH building.[20]
  • A " Direct Light Sampling Cache" to accelerate scenes with many light sources.[21][22]
  • A "Photon Global Illumination" cache to accelerate complex scenes, including support for caustic photon cache and vertex merging.[23][24]
  • Support for Open Intel Image Denoiser (OIDN).[23][25]
  • Blender Cycles scene conversion, including (limited) support for automatic interpretation of Cycles materials and textures.[26]
  • Advanced material properties, including glass dispersion (using Cauchy's transmission equation), rough glass (for creating frosted glass or ice), metal, car paint (using multiple reflective coatings), and velvet (to represent fuzzy surfaces).[27]
  • Support for physically based light units like lumen and candela, as well as traditional gain and exposure controls.[26]
  • Support for subdivision shapes, displacement shapes, and vector displacement of displacement shapes.[26]

LuxRender 1.0

[edit]

New features included in LuxRender 1.0 include:[28]

  • An experimental Stochastic Progressive Photon Mapping integrator (SPPM).[29]
  • GPU-accelerated "Hybrid Bidirectional" path tracing using the GPU for ray-intersection calculations.
  • Support for multiple GPUs.
  • New and updated materials, including metal, car paint, glossy coating, and layered materials.

LuxRender 0.8

[edit]

The main features of LuxRender as of version 0.8 include:[11][30]

  • Biased and unbiased rendering: Users can choose between physical accuracy (unbiased) and speed (biased).
  • Full spectral rendering: Instead of discrete RGB colour bands, full spectra are used for internal calculations.
  • Hierarchical procedural and image based texture system: Procedural and image based textures can be mixed in various ways, making it possible to create complex materials.
  • Displacement mapping and subdivision: Based on procedural or image textures, object surfaces can be transformed.
  • Network and co-operative rendering: Rendering time can be reduced by combining the processing power of multiple computers. IPv6 is also supported.
  • Perspective (including shift lens), orthographic and environment cameras.
  • HDR output: Render output can be saved in various file formats, including .png, .tga and .exr.
  • Instances: Instancing significantly saves system resources, in particular memory consumption by reusing mesh data in duplicated objects.
  • Built in post-processing: While rendering, you can add post processed effects like bloom, glare, chromatic aberration and vignetting.
  • Motion blur, depth of field and lens effects: True motion blur, both for the camera and individual objects, and physically accurate Lens Effects, including Depth Of Field.
  • Light groups: By using light groups, one can output various light situations from a single rendering, or make adjustments to the balance between light sources in real time.
  • Tone mapping
  • Image denoising
  • Fleximage (virtual film): Allows you to pause and continue renders. The current state of the render can be written to a file, so that any system can continue the render at a later moment.
  • GPU acceleration for path tracing when sampling one light at a time.[31]
  • Film response curves to emulate traditional cameras color response (some curves are for black&white films too).
  • Volumetric rendering using Homogeneous volumes by defining an interior, and exterior volume.
  • Subsurface Scattering

References

[edit]
  1. ^ a b "Authors". LuxRender. Archived from the original on 2011-03-01. Retrieved 2008-06-30.
  2. ^ "LuxCoreRender v2.6". GitHub. 2021-12-25. Retrieved 2021-12-27.
  3. ^ "LuxCoreRender team releases LuxCoreRender 2.2". BlenderNation. 2019-10-02. Retrieved 2020-03-11.
  4. ^ "LuxCore API – LuxCoreRender". Retrieved 2020-03-27.
  5. ^ "Exporter Status - LuxRender Wiki". 2016-04-19. Archived from the original on 2016-04-19. Retrieved 2020-03-27.
  6. ^ "LuxRender - 3DS Max". 2018-04-14. Archived from the original on 2018-04-14. Retrieved 2020-03-27.
  7. ^ "Download – LuxCoreRender". Retrieved 2020-03-27.
  8. ^ "Luxrender Manual - LuxRender Wiki". Archived from the original on 2011-02-11. Retrieved 2012-06-20.
  9. ^ "LuxRender Light groups - LuxRender Wiki". 2016-02-15. Archived from the original on 2016-02-15. Retrieved 2020-03-27.
  10. ^ a b "LuxCoreRender Light Groups - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  11. ^ a b "Features". LuxRender. Archived from the original on 2011-03-09. Retrieved 2008-06-30.
  12. ^ "LuxRender 0.5 released". BlenderNation. 2008-06-30. Retrieved 2008-06-30.
  13. ^ "Luxrender and OpenCL - LuxRender Wiki". 2018-04-13. Archived from the original on 2018-04-13. Retrieved 2020-03-27.
  14. ^ "Re: Spectral rendering and color management questions". forums.luxcorerender.org. 2018-06-03. Retrieved 2024-06-25.
  15. ^ "Re: Spectral rendering and color management questions". forums.luxcorerender.org. 2018-06-04. Retrieved 2024-06-25.
  16. ^ "Incorrect color spectrum". github.com/LuxCoreRender/LuxCore/issues/262. 2019-11-14. Retrieved 2024-06-25.
  17. ^ "New Features in v2.5 – LuxCoreRender".
  18. ^ "LuxCoreRender Release Notes v2.4 - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-07-27.
  19. ^ "LuxCoreRender Release Notes - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  20. ^ "LuxCoreRender Release Notes v2.0 - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  21. ^ "LuxCoreRender Release Notes v2.1 - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  22. ^ "Direct Light Sampling Cache (aka Light cache part I) - LuxCoreRender Forums". forums.luxcorerender.org. Retrieved 2020-03-27.
  23. ^ a b "LuxCoreRender Release Notes v2.2 - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  24. ^ "PhotonGI cache - LuxCoreRender Forums". forums.luxcorerender.org. Retrieved 2020-03-27.
  25. ^ "OpenImageDenoise - LuxCoreRender Forums". forums.luxcorerender.org. Retrieved 2020-03-27.
  26. ^ a b c "LuxCoreRender v2.3 released - LuxCoreRender Forums". forums.luxcorerender.org. Retrieved 2020-03-29.
  27. ^ "LuxCoreRender Materials - LuxCoreRender Wiki". wiki.luxcorerender.org. Retrieved 2020-03-27.
  28. ^ "New in 1.0 - LuxRender Wiki". 2016-04-19. Archived from the original on 2016-04-19. Retrieved 2020-03-27.
  29. ^ "SPPM - LuxRender Wiki". 2016-05-02. Archived from the original on 2016-05-02. Retrieved 2020-03-27.
  30. ^ "New in 0-8 - LuxRender Wiki". 2016-05-04. Archived from the original on 2016-05-04. Retrieved 2020-03-27.
  31. ^ "GPU - LuxRender Wiki". 1 July 2014. Archived from the original on 25 October 2011. Retrieved 9 June 2011.
[edit]