[Bf-blender-cvs] [3bba3d3] soc-2016-cycles_denoising: Cycles: Support filter strength for denoising after rendering

Lukas Stockner noreply at git.blender.org
Sat Sep 10 00:20:44 CEST 2016


Commit: 3bba3d32412f2e30e4bd5b7d19cfed77b7f5594f
Author: Lukas Stockner
Date:   Fri Sep 9 17:01:49 2016 +0200
Branches: soc-2016-cycles_denoising
https://developer.blender.org/rB3bba3d32412f2e30e4bd5b7d19cfed77b7f5594f

Cycles: Support filter strength for denoising after rendering

===================================================================

M	intern/cycles/blender/blender_session.cpp
M	intern/cycles/render/session.cpp
M	intern/cycles/render/session.h

===================================================================

diff --git a/intern/cycles/blender/blender_session.cpp b/intern/cycles/blender/blender_session.cpp
index 4274fa9..e30eec5 100644
--- a/intern/cycles/blender/blender_session.cpp
+++ b/intern/cycles/blender/blender_session.cpp
@@ -1379,9 +1379,11 @@ void BlenderSession::denoise(BL::RenderResult& b_rr)
 		BL::RenderSettings r = b_scene.render();
 		BL::RenderSettings::layers_iterator b_s_layer_iter;
 		int half_window = -1;
+		float filter_strength = 0.0f;
 		for(r.layers.begin(b_s_layer_iter); b_s_layer_iter != r.layers.end(); ++b_s_layer_iter) {
 			if(b_s_layer_iter->name() == b_layer_iter->name()) {
 				half_window = b_s_layer_iter->half_window();
+				filter_strength = b_s_layer_iter->filter_strength();
 				break;
 			}
 		}
@@ -1389,6 +1391,7 @@ void BlenderSession::denoise(BL::RenderResult& b_rr)
 
 		session->params.half_window = half_window;
 		session->params.samples = get_int(cscene, "samples");
+		session->params.filter_strength = powf(2.0f, filter_strength);
 
 		session->buffers = BlenderSync::get_render_buffer(session->device, *b_layer_iter, b_rr, session->params.samples);
 
diff --git a/intern/cycles/render/session.cpp b/intern/cycles/render/session.cpp
index a5a42cd..568405b 100644
--- a/intern/cycles/render/session.cpp
+++ b/intern/cycles/render/session.cpp
@@ -806,7 +806,7 @@ void Session::run_denoise()
 		kernel_data.film.num_frames = buffers->params.frames;
 		kernel_data.film.prev_frames = params.prev_frames;
 		if(scene == NULL) {
-			kernel_data.integrator.filter_strength = 1.0f;
+			kernel_data.integrator.filter_strength = params.filter_strength;
 		}
 		device->const_copy_to("__data", &kernel_data, sizeof(kernel_data));
 
diff --git a/intern/cycles/render/session.h b/intern/cycles/render/session.h
index 8b73365..42e4d4d 100644
--- a/intern/cycles/render/session.h
+++ b/intern/cycles/render/session.h
@@ -64,6 +64,7 @@ public:
 
 	bool only_denoise;
 	int half_window;
+	float filter_strength;
 	int prev_frames;
 
 	double cancel_timeout;
@@ -95,6 +96,7 @@ public:
 
 		only_denoise = false;
 		half_window = 8;
+		filter_strength = 1.0f;
 		prev_frames = 0;
 
 		cancel_timeout = 0.1;
@@ -123,6 +125,7 @@ public:
 		&& denoise_result == params.denoise_result
 		&& only_denoise == params.only_denoise
 		&& half_window == params.half_window
+		&& filter_strength == params.filter_strength
 		&& prev_frames == params.prev_frames
 		&& display_buffer_linear == params.display_buffer_linear
 		&& cancel_timeout == params.cancel_timeout




More information about the Bf-blender-cvs mailing list