diff options
author | Brecht Van Lommel <brechtvanlommel@pandora.be> | 2012-06-13 15:44:48 +0400 |
---|---|---|
committer | Brecht Van Lommel <brechtvanlommel@pandora.be> | 2012-06-13 15:44:48 +0400 |
commit | 4ba456d1754c29b488b8304c8546af45078e8536 (patch) | |
tree | 49649b7442d58aa835a7428043130f158613521d /intern/cycles/kernel/kernel_types.h | |
parent | dcda234a3d93ed44189fac3716a694f4f75f366e (diff) |
Cycles: first step for implementation of non-progressive sampler that handles
direct and indirect lighting differently. Rather than picking one light for each
point on the path, it now loops over all lights for direct lighting. For indirect
lighting it still picks a random light each time.
It gives control over the number of AA samples, and the number of Diffuse, Glossy,
Transmission, AO, Mesh Light, Background and Lamp samples for each AA sample.
This helps tuning render performance/noise and tends to give less noise for renders
dominated by direct lighting.
This sampling mode only works on the CPU, and still needs proper tile rendering
to show progress (will follow tommorrow or so), because each AA sample can be quite
slow now and so the delay between each update wil be too long.
Diffstat (limited to 'intern/cycles/kernel/kernel_types.h')
-rw-r--r-- | intern/cycles/kernel/kernel_types.h | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/intern/cycles/kernel/kernel_types.h b/intern/cycles/kernel/kernel_types.h index 77a800b0e67..d204b114b8e 100644 --- a/intern/cycles/kernel/kernel_types.h +++ b/intern/cycles/kernel/kernel_types.h @@ -43,6 +43,7 @@ CCL_NAMESPACE_BEGIN #ifdef WITH_OSL #define __OSL__ #endif +#define __NON_PROGRESSIVE__ #endif #ifdef __KERNEL_CUDA__ @@ -110,7 +111,6 @@ CCL_NAMESPACE_BEGIN //#define __MOTION__ #endif -//#define __MULTI_LIGHT__ //#define __SOBOL_FULL_SCREEN__ //#define __QBVH__ @@ -627,6 +627,15 @@ typedef struct KernelIntegrator { /* clamp */ float sample_clamp; + + /* non-progressive */ + int progressive; + int diffuse_samples; + int glossy_samples; + int transmission_samples; + int ao_samples; + int mesh_light_samples; + int pad1, pad2; } KernelIntegrator; typedef struct KernelBVH { |