Abstract
Multiple importance sampling (MIS) is an indispensable tool in rendering that constructs robust sampling strategies by combining the respective strengths of individual distributions. Its efficiency can be greatly improved by carefully selecting the number of samples drawn from each distribution, but automating this process remains a challenging problem. Existing works are mostly limited to mixture sampling, in which only a single sample is drawn in total, and the works that do investigate multi-sample MIS only optimize the sample counts at a per-pixel level, which cannot account for variations beyond the first bounce. Recent work on Russian roulette and splitting has demonstrated how fixed-point schemes can be used to spatially vary sample counts to optimize image efficiency but is limited to choosing the same number of samples across all sampling strategies. Our work proposes a highly flexible sample allocation strategy that bridges the gap between these areas of work. We show how to iteratively optimize the sample counts to maximize the efficiency of the rendered image using a lightweight data structure, which allows us to make local and individual decisions per technique. We demonstrate the benefits of our approach in two applications, path guiding and bidirectional path tracing, in both of which we achieve consistent and substantial speedups over the respective previous state-of-the-art.
Citing MARS
1@inproceedings{meyerMARSMultisampleAllocation2024,
2 author = {Meyer, Joshua and Rath, Alexander and Yazici, \"{O}mercan and Slusallek, Philipp},
3 title = {{{MARS}}: {{Multi-sample Allocation}} through {{Russian}} roulette and {{Splitting}}},
4 shorttitle = {MARS},
5 year = {2024},
6 month = {dec},
7 isbn = {9798400711312},
8 publisher = {Association for Computing Machinery},
9 address = {New York, NY, USA},
10 url = {https://doi.org/10.1145/3680528.3687636},
11 doi = {10.1145/3680528.3687636},
12 booktitle = {SIGGRAPH Asia 2024 Conference Papers},
13 articleno = {20},
14 numpages = {10},
15 keywords = {Russian roulette, splitting, multi-sample, multiple importance sampling},
16 series = {SA '24}
17}
Comments