Cycles Denoising: Add more failsafes for invalid pixels
[blender.git] / intern / cycles / kernel / filter / filter_reconstruction.h
index d6d7639a22d0461d4baec9f7c5a62715e2209c38..25a3025056c0bc0469cb5d90ee2498ca0beef390 100644 (file)
@@ -81,6 +81,12 @@ ccl_device_inline void kernel_filter_finalize(int x, int y, int w, int h,
        (void) storage_stride;
 #endif
 
+       if(XtWX[0] < 1e-3f) {
+               /* There is not enough information to determine a denoised result.
+                * As a fallback, keep the original value of the pixel. */
+                return;
+       }
+
        /* The weighted average of pixel colors (essentially, the NLM-filtered image).
         * In case the solution of the linear model fails due to numerical issues,
         * fall back to this value. */
@@ -93,6 +99,9 @@ ccl_device_inline void kernel_filter_finalize(int x, int y, int w, int h,
                final_color = mean_color;
        }
 
+       /* Clamp pixel value to positive values. */
+       final_color = max(final_color, make_float3(0.0f, 0.0f, 0.0f));
+
        ccl_global float *combined_buffer = buffer + (y*buffer_params.y + x + buffer_params.x)*buffer_params.z;
        final_color *= sample;
        if(buffer_params.w) {