| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-08-18 14:16:15 +00:00
										 |  |  |  * Copyright 2011-2013 Blender Foundation | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-08-18 14:16:15 +00:00
										 |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-08-18 14:16:15 +00:00
										 |  |  |  * http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-08-18 14:16:15 +00:00
										 |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * ShaderData, used in four steps: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Setup from incoming ray, sampled position and background. | 
					
						
							|  |  |  |  * Execute for surface, volume or displacement. | 
					
						
							|  |  |  |  * Evaluate one or more closures. | 
					
						
							|  |  |  |  * Release. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | #include "closure/bsdf_util.h"
 | 
					
						
							| 
									
										
										
										
											2012-10-20 12:18:00 +00:00
										 |  |  | #include "closure/bsdf.h"
 | 
					
						
							|  |  |  | #include "closure/emissive.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #include "svm/svm.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CCL_NAMESPACE_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ShaderData setup from incoming ray */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-17 22:48:29 +00:00
										 |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_setup_object_transforms(KernelGlobals *kg, ShaderData *sd, float time) | 
					
						
							| 
									
										
										
										
											2012-10-17 22:48:29 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if(sd->flag & SD_OBJECT_MOTION) { | 
					
						
							|  |  |  | 		sd->ob_tfm = object_fetch_transform_motion(kg, sd->object, time); | 
					
						
							| 
									
										
										
										
											2014-05-05 02:19:08 +10:00
										 |  |  | 		sd->ob_itfm = transform_quick_inverse(sd->ob_tfm); | 
					
						
							| 
									
										
										
										
											2012-10-17 22:48:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		sd->ob_tfm = object_fetch_transform(kg, sd->object, OBJECT_TRANSFORM); | 
					
						
							|  |  |  | 		sd->ob_itfm = object_fetch_transform(kg, sd->object, OBJECT_INVERSE_TRANSFORM); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_setup_from_ray(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	const Intersection *isect, const Ray *ray, int bounce, int transparent_bounce) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->object = (isect->object == PRIM_NONE)? kernel_tex_fetch(__prim_object, isect->prim): isect->object; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-10-15 21:12:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	sd->type = isect->type; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:07:06 +00:00
										 |  |  | 	sd->flag = kernel_tex_fetch(__object_flag, sd->object); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	/* matrices and time */ | 
					
						
							| 
									
										
										
										
											2012-10-09 18:37:14 +00:00
										 |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							| 
									
										
										
										
											2012-10-17 22:48:29 +00:00
										 |  |  | 	shader_setup_object_transforms(kg, sd, ray->time); | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	sd->time = ray->time; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 	sd->prim = kernel_tex_fetch(__prim_index, isect->prim); | 
					
						
							| 
									
										
										
										
											2012-05-02 17:03:46 +00:00
										 |  |  | 	sd->ray_length = isect->t; | 
					
						
							| 
									
										
										
										
											2013-07-31 20:30:37 +00:00
										 |  |  | 	sd->ray_depth = bounce; | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	sd->transparent_depth = transparent_bounce; | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | #ifdef __UV__
 | 
					
						
							|  |  |  | 	sd->u = isect->u; | 
					
						
							|  |  |  | 	sd->v = isect->v; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | #ifdef __HAIR__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	if(sd->type & PRIMITIVE_ALL_CURVE) { | 
					
						
							|  |  |  | 		/* curve */ | 
					
						
							| 
									
										
										
										
											2013-01-03 12:09:09 +00:00
										 |  |  | 		float4 curvedata = kernel_tex_fetch(__curves, sd->prim); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-03 12:09:09 +00:00
										 |  |  | 		sd->shader = __float_as_int(curvedata.z); | 
					
						
							| 
									
										
										
										
											2013-12-14 13:11:44 +01:00
										 |  |  | 		sd->P = bvh_curve_refine(kg, sd, isect, ray); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(sd->type & PRIMITIVE_TRIANGLE) { | 
					
						
							|  |  |  | 		/* static triangle */ | 
					
						
							| 
									
										
										
										
											2014-06-13 21:27:21 +02:00
										 |  |  | 		float3 Ng = triangle_normal(kg, sd->prim); | 
					
						
							|  |  |  | 		sd->shader =  __float_as_int(kernel_tex_fetch(__tri_shader, sd->prim)); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* vectors */ | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:45 +01:00
										 |  |  | 		sd->P = triangle_refine(kg, sd, isect, ray); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 		sd->Ng = Ng; | 
					
						
							|  |  |  | 		sd->N = Ng; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* smooth normal */ | 
					
						
							|  |  |  | 		if(sd->shader & SHADER_SMOOTH_NORMAL) | 
					
						
							|  |  |  | 			sd->N = triangle_smooth_normal(kg, sd->prim, sd->u, sd->v); | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __DPDU__
 | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 		/* dPdu/dPdv */ | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:45 +01:00
										 |  |  | 		triangle_dPdudv(kg, sd->prim, &sd->dPdu, &sd->dPdv); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		/* motion triangle */ | 
					
						
							|  |  |  | 		motion_triangle_shader_setup(kg, sd, isect, ray, false); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	sd->I = -ray->D; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:07:06 +00:00
										 |  |  | 	sd->flag |= kernel_tex_fetch(__shader_flag, (sd->shader & SHADER_MASK)*2); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(isect->object != OBJECT_NONE) { | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		/* instance transform */ | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 		object_normal_transform(kg, sd, &sd->N); | 
					
						
							|  |  |  | 		object_normal_transform(kg, sd, &sd->Ng); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __DPDU__
 | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 		object_dir_transform(kg, sd, &sd->dPdu); | 
					
						
							|  |  |  | 		object_dir_transform(kg, sd, &sd->dPdv); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* backfacing test */ | 
					
						
							|  |  |  | 	bool backfacing = (dot(sd->Ng, sd->I) < 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(backfacing) { | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 		sd->flag |= SD_BACKFACING; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		sd->Ng = -sd->Ng; | 
					
						
							|  |  |  | 		sd->N = -sd->N; | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 		sd->dPdu = -sd->dPdu; | 
					
						
							|  |  |  | 		sd->dPdv = -sd->dPdv; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __RAY_DIFFERENTIALS__
 | 
					
						
							|  |  |  | 	/* differentials */ | 
					
						
							|  |  |  | 	differential_transfer(&sd->dP, ray->dP, ray->D, ray->dD, sd->Ng, isect->t); | 
					
						
							|  |  |  | 	differential_incoming(&sd->dI, ray->dD); | 
					
						
							|  |  |  | 	differential_dudv(&sd->du, &sd->dv, sd->dPdu, sd->dPdv, sd->dP, sd->Ng); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | /* ShaderData setup from BSSRDF scatter */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __SUBSURFACE__
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device_inline void shader_setup_from_subsurface(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 	const Intersection *isect, const Ray *ray) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bool backfacing = sd->flag & SD_BACKFACING; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* object, matrices, time, ray_length stay the same */ | 
					
						
							|  |  |  | 	sd->flag = kernel_tex_fetch(__object_flag, sd->object); | 
					
						
							|  |  |  | 	sd->prim = kernel_tex_fetch(__prim_index, isect->prim); | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	sd->type = isect->type; | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __UV__
 | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 	sd->u = isect->u; | 
					
						
							|  |  |  | 	sd->v = isect->v; | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	/* fetch triangle data */ | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(sd->type == PRIMITIVE_TRIANGLE) { | 
					
						
							| 
									
										
										
										
											2014-06-13 21:27:21 +02:00
										 |  |  | 		float3 Ng = triangle_normal(kg, sd->prim); | 
					
						
							|  |  |  | 		sd->shader =  __float_as_int(kernel_tex_fetch(__tri_shader, sd->prim)); | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* static triangle */ | 
					
						
							|  |  |  | 		sd->P = triangle_refine_subsurface(kg, sd, isect, ray); | 
					
						
							|  |  |  | 		sd->Ng = Ng; | 
					
						
							|  |  |  | 		sd->N = Ng; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(sd->shader & SHADER_SMOOTH_NORMAL) | 
					
						
							|  |  |  | 			sd->N = triangle_smooth_normal(kg, sd->prim, sd->u, sd->v); | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 		/* dPdu/dPdv */ | 
					
						
							|  |  |  | 		triangle_dPdudv(kg, sd->prim, &sd->dPdu, &sd->dPdv); | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		/* motion triangle */ | 
					
						
							|  |  |  | 		motion_triangle_shader_setup(kg, sd, isect, ray, true); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	sd->flag |= kernel_tex_fetch(__shader_flag, (sd->shader & SHADER_MASK)*2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(isect->object != OBJECT_NONE) { | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 		/* instance transform */ | 
					
						
							|  |  |  | 		object_normal_transform(kg, sd, &sd->N); | 
					
						
							|  |  |  | 		object_normal_transform(kg, sd, &sd->Ng); | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 		object_dir_transform(kg, sd, &sd->dPdu); | 
					
						
							|  |  |  | 		object_dir_transform(kg, sd, &sd->dPdv); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* backfacing test */ | 
					
						
							|  |  |  | 	if(backfacing) { | 
					
						
							|  |  |  | 		sd->flag |= SD_BACKFACING; | 
					
						
							|  |  |  | 		sd->Ng = -sd->Ng; | 
					
						
							|  |  |  | 		sd->N = -sd->N; | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 		sd->dPdu = -sd->dPdu; | 
					
						
							|  |  |  | 		sd->dPdv = -sd->dPdv; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* should not get used in principle as the shading will only use a diffuse
 | 
					
						
							|  |  |  | 	 * BSDF, but the shader might still access it */ | 
					
						
							|  |  |  | 	sd->I = sd->N; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __RAY_DIFFERENTIALS__
 | 
					
						
							|  |  |  | 	/* differentials */ | 
					
						
							|  |  |  | 	differential_dudv(&sd->du, &sd->dv, sd->dPdu, sd->dPdv, sd->dP, sd->Ng); | 
					
						
							|  |  |  | 	/* don't modify dP and dI */ | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* ShaderData setup from position sampled on mesh */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_setup_from_sample(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	const float3 P, const float3 Ng, const float3 I, | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	int shader, int object, int prim, float u, float v, float t, float time, int bounce, int transparent_bounce) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* vectors */ | 
					
						
							|  |  |  | 	sd->P = P; | 
					
						
							|  |  |  | 	sd->N = Ng; | 
					
						
							|  |  |  | 	sd->Ng = Ng; | 
					
						
							|  |  |  | 	sd->I = I; | 
					
						
							|  |  |  | 	sd->shader = shader; | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->type = (prim == PRIM_NONE)? PRIMITIVE_NONE: PRIMITIVE_TRIANGLE; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* primitive */ | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							|  |  |  | 	sd->object = object; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-09-15 23:58:00 +00:00
										 |  |  | 	/* currently no access to bvh prim index for strand sd->prim*/ | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	sd->prim = prim; | 
					
						
							|  |  |  | #ifdef __UV__
 | 
					
						
							|  |  |  | 	sd->u = u; | 
					
						
							|  |  |  | 	sd->v = v; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-05-02 17:03:46 +00:00
										 |  |  | 	sd->ray_length = t; | 
					
						
							| 
									
										
										
										
											2013-07-31 20:30:37 +00:00
										 |  |  | 	sd->ray_depth = bounce; | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	sd->transparent_depth = transparent_bounce; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* detect instancing, for non-instanced the object index is -object-1 */ | 
					
						
							| 
									
										
										
										
											2011-08-10 14:26:51 +00:00
										 |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	bool instanced = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(sd->prim != PRIM_NONE) { | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		if(sd->object >= 0) | 
					
						
							|  |  |  | 			instanced = true; | 
					
						
							|  |  |  | 		else | 
					
						
							| 
									
										
										
										
											2011-08-10 14:26:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-01-18 22:36:12 +00:00
										 |  |  | 			sd->object = ~sd->object; | 
					
						
							| 
									
										
										
										
											2011-08-10 14:26:51 +00:00
										 |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-08-10 14:26:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-15 21:12:58 +00:00
										 |  |  | 	sd->flag = kernel_tex_fetch(__shader_flag, (sd->shader & SHADER_MASK)*2); | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(sd->object != OBJECT_NONE) { | 
					
						
							| 
									
										
										
										
											2012-10-15 21:12:58 +00:00
										 |  |  | 		sd->flag |= kernel_tex_fetch(__object_flag, sd->object); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-09 18:37:14 +00:00
										 |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							| 
									
										
										
										
											2012-10-17 22:48:29 +00:00
										 |  |  | 		shader_setup_object_transforms(kg, sd, time); | 
					
						
							| 
									
										
										
										
											2012-10-15 21:12:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-15 21:12:58 +00:00
										 |  |  | 	sd->time = time; | 
					
						
							| 
									
										
										
										
											2012-10-16 13:20:57 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	if(sd->type & PRIMITIVE_TRIANGLE) { | 
					
						
							|  |  |  | 		/* smooth normal */ | 
					
						
							|  |  |  | 		if(sd->shader & SHADER_SMOOTH_NORMAL) { | 
					
						
							|  |  |  | 			sd->N = triangle_smooth_normal(kg, sd->prim, sd->u, sd->v); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 			if(instanced) | 
					
						
							|  |  |  | 				object_normal_transform(kg, sd, &sd->N); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 		/* dPdu/dPdv */ | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __DPDU__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:45 +01:00
										 |  |  | 		triangle_dPdudv(kg, sd->prim, &sd->dPdu, &sd->dPdv); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							|  |  |  | 		if(instanced) { | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 			object_dir_transform(kg, sd, &sd->dPdu); | 
					
						
							|  |  |  | 			object_dir_transform(kg, sd, &sd->dPdv); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	else { | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 		sd->dPdu = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 		sd->dPdv = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* backfacing test */ | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	if(sd->prim != PRIM_NONE) { | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		bool backfacing = (dot(sd->Ng, sd->I) < 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(backfacing) { | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 			sd->flag |= SD_BACKFACING; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 			sd->Ng = -sd->Ng; | 
					
						
							|  |  |  | 			sd->N = -sd->N; | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 			sd->dPdu = -sd->dPdu; | 
					
						
							|  |  |  | 			sd->dPdv = -sd->dPdv; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __RAY_DIFFERENTIALS__
 | 
					
						
							|  |  |  | 	/* no ray differentials here yet */ | 
					
						
							| 
									
										
										
										
											2013-05-03 21:34:51 +00:00
										 |  |  | 	sd->dP = differential3_zero(); | 
					
						
							|  |  |  | 	sd->dI = differential3_zero(); | 
					
						
							|  |  |  | 	sd->du = differential_zero(); | 
					
						
							|  |  |  | 	sd->dv = differential_zero(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ShaderData setup for displacement */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_setup_from_displace(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	int object, int prim, float u, float v) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float3 P, Ng, I = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 	int shader; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:45 +01:00
										 |  |  | 	triangle_point_normal(kg, prim, u, v, &P, &Ng, &shader); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* force smooth shading for displacement */ | 
					
						
							| 
									
										
										
										
											2011-11-22 13:15:19 +00:00
										 |  |  | 	shader |= SHADER_SMOOTH_NORMAL; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* watch out: no instance transform currently */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	shader_setup_from_sample(kg, sd, P, Ng, I, shader, object, prim, u, v, 0.0f, TIME_INVALID, 0, 0); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ShaderData setup from ray into background */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | ccl_device_inline void shader_setup_from_background(KernelGlobals *kg, ShaderData *sd, const Ray *ray, int bounce, int transparent_bounce) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* vectors */ | 
					
						
							|  |  |  | 	sd->P = ray->D; | 
					
						
							| 
									
										
										
										
											2013-06-08 10:51:33 +00:00
										 |  |  | 	sd->N = -ray->D; | 
					
						
							|  |  |  | 	sd->Ng = -ray->D; | 
					
						
							|  |  |  | 	sd->I = -ray->D; | 
					
						
							| 
									
										
										
										
											2013-12-28 02:27:48 +01:00
										 |  |  | 	sd->shader = kernel_data.background.surface_shader; | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	sd->flag = kernel_tex_fetch(__shader_flag, (sd->shader & SHADER_MASK)*2); | 
					
						
							| 
									
										
										
										
											2012-10-09 18:37:14 +00:00
										 |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	sd->time = ray->time; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-05-02 17:03:46 +00:00
										 |  |  | 	sd->ray_length = 0.0f; | 
					
						
							| 
									
										
										
										
											2013-07-31 20:30:37 +00:00
										 |  |  | 	sd->ray_depth = bounce; | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	sd->transparent_depth = transparent_bounce; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->object = PRIM_NONE; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->prim = PRIM_NONE; | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | #ifdef __UV__
 | 
					
						
							|  |  |  | 	sd->u = 0.0f; | 
					
						
							|  |  |  | 	sd->v = 0.0f; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 	/* dPdu/dPdv */ | 
					
						
							|  |  |  | 	sd->dPdu = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 	sd->dPdv = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __RAY_DIFFERENTIALS__
 | 
					
						
							|  |  |  | 	/* differentials */ | 
					
						
							|  |  |  | 	sd->dP = ray->dD; | 
					
						
							|  |  |  | 	differential_incoming(&sd->dI, sd->dP); | 
					
						
							|  |  |  | 	sd->du.dx = 0.0f; | 
					
						
							|  |  |  | 	sd->du.dy = 0.0f; | 
					
						
							|  |  |  | 	sd->dv.dx = 0.0f; | 
					
						
							|  |  |  | 	sd->dv.dy = 0.0f; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ShaderData setup from point inside volume */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | ccl_device_inline void shader_setup_from_volume(KernelGlobals *kg, ShaderData *sd, const Ray *ray, int bounce, int transparent_bounce) | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* vectors */ | 
					
						
							|  |  |  | 	sd->P = ray->P; | 
					
						
							|  |  |  | 	sd->N = -ray->D;   | 
					
						
							|  |  |  | 	sd->Ng = -ray->D; | 
					
						
							|  |  |  | 	sd->I = -ray->D; | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->shader = SHADER_NONE; | 
					
						
							| 
									
										
										
										
											2013-12-28 23:00:51 +01:00
										 |  |  | 	sd->flag = 0; | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							|  |  |  | 	sd->time = ray->time; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	sd->ray_length = 0.0f; /* todo: can we set this to some useful value? */ | 
					
						
							|  |  |  | 	sd->ray_depth = bounce; | 
					
						
							| 
									
										
										
										
											2014-04-21 14:20:29 +02:00
										 |  |  | 	sd->transparent_depth = transparent_bounce; | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __INSTANCING__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->object = PRIM_NONE; /* todo: fill this for texture coordinates */ | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	sd->prim = PRIM_NONE; | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	sd->type = PRIMITIVE_NONE; | 
					
						
							| 
									
										
										
										
											2013-12-28 16:56:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __UV__
 | 
					
						
							|  |  |  | 	sd->u = 0.0f; | 
					
						
							|  |  |  | 	sd->v = 0.0f; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __DPDU__
 | 
					
						
							|  |  |  | 	/* dPdu/dPdv */ | 
					
						
							|  |  |  | 	sd->dPdu = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 	sd->dPdv = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __RAY_DIFFERENTIALS__
 | 
					
						
							|  |  |  | 	/* differentials */ | 
					
						
							|  |  |  | 	sd->dP = ray->dD; | 
					
						
							|  |  |  | 	differential_incoming(&sd->dI, sd->dP); | 
					
						
							| 
									
										
										
										
											2013-05-03 21:34:51 +00:00
										 |  |  | 	sd->du = differential_zero(); | 
					
						
							|  |  |  | 	sd->dv = differential_zero(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-06-08 10:51:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* for NDC coordinates */ | 
					
						
							|  |  |  | 	sd->ray_P = ray->P; | 
					
						
							|  |  |  | 	sd->ray_dP = ray->dP; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | /* Merging */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(__BRANCHED_PATH__) || defined(__VOLUME__)
 | 
					
						
							|  |  |  | ccl_device void shader_merge_closures(ShaderData *sd) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* merge identical closures, better when we sample a single closure at a time */ | 
					
						
							|  |  |  | 	for(int i = 0; i < sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sci = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(int j = i + 1; j < sd->num_closure; j++) { | 
					
						
							|  |  |  | 			ShaderClosure *scj = &sd->closure[j]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __OSL__
 | 
					
						
							| 
									
										
										
										
											2014-04-03 15:51:43 +02:00
										 |  |  | 			if(sci->prim || scj->prim) | 
					
						
							|  |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-03 15:51:43 +02:00
										 |  |  | 			if(!(sci->type == scj->type && sci->data0 == scj->data0 && sci->data1 == scj->data1)) | 
					
						
							|  |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-03 15:51:43 +02:00
										 |  |  | 			if(CLOSURE_IS_BSDF_OR_BSSRDF(sci->type)) { | 
					
						
							|  |  |  | 				if(sci->N != scj->N) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				else if(CLOSURE_IS_BSDF_ANISOTROPIC(sci->type) && sci->T != scj->T) | 
					
						
							|  |  |  | 					continue; | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-04-03 15:51:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			sci->weight += scj->weight; | 
					
						
							|  |  |  | 			sci->sample_weight += scj->sample_weight; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			int size = sd->num_closure - (j+1); | 
					
						
							|  |  |  | 			if(size > 0) { | 
					
						
							|  |  |  | 				for(int k = 0; k < size; k++) { | 
					
						
							|  |  |  | 					scj[k] = scj[k+1]; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			sd->num_closure--; | 
					
						
							|  |  |  | 			j--; | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* BSDF */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device_inline void _shader_bsdf_multi_eval(KernelGlobals *kg, const ShaderData *sd, const float3 omega_in, float *pdf, | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 	int skip_bsdf, BsdfEval *result_eval, float sum_pdf, float sum_sample_weight) | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 	/* this is the veach one-sample model with balance heuristic, some pdf
 | 
					
						
							|  |  |  | 	 * factors drop out when using balance heuristic weighting */ | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		if(i == skip_bsdf) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		const ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSDF(sc->type)) { | 
					
						
							|  |  |  | 			float bsdf_pdf = 0.0f; | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 			float3 eval = bsdf_eval(kg, sd, sc, omega_in, &bsdf_pdf); | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 			if(bsdf_pdf != 0.0f) { | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 				bsdf_eval_accum(result_eval, sc->type, eval*sc->weight); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 				sum_pdf += bsdf_pdf*sc->sample_weight; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			sum_sample_weight += sc->sample_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-31 15:59:30 +00:00
										 |  |  | 	*pdf = (sum_sample_weight > 0.0f)? sum_pdf/sum_sample_weight: 0.0f; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_bsdf_eval(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	const float3 omega_in, BsdfEval *eval, float *pdf) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	bsdf_eval_init(eval, NBUILTIN_CLOSURES, make_float3(0.0f, 0.0f, 0.0f), kernel_data.film.use_light_pass); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-14 19:38:14 +00:00
										 |  |  | 	_shader_bsdf_multi_eval(kg, sd, omega_in, pdf, -1, eval, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device int shader_bsdf_sample(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	float randu, float randv, BsdfEval *bsdf_eval, | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	float3 *omega_in, differential3 *domega_in, float *pdf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int sampled = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(sd->num_closure > 1) { | 
					
						
							|  |  |  | 		/* pick a BSDF closure based on sample weights */ | 
					
						
							|  |  |  | 		float sum = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(sampled = 0; sampled < sd->num_closure; sampled++) { | 
					
						
							|  |  |  | 			const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(CLOSURE_IS_BSDF(sc->type)) | 
					
						
							|  |  |  | 				sum += sc->sample_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		float r = sd->randb_closure*sum; | 
					
						
							|  |  |  | 		sum = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(sampled = 0; sampled < sd->num_closure; sampled++) { | 
					
						
							|  |  |  | 			const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(CLOSURE_IS_BSDF(sc->type)) { | 
					
						
							| 
									
										
										
										
											2013-04-01 20:26:52 +00:00
										 |  |  | 				sum += sc->sample_weight; | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if(r <= sum) | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(sampled == sd->num_closure) { | 
					
						
							|  |  |  | 			*pdf = 0.0f; | 
					
						
							|  |  |  | 			return LABEL_NONE; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 	int label; | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	float3 eval; | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	*pdf = 0.0f; | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 	label = bsdf_sample(kg, sd, sc, randu, randv, &eval, omega_in, domega_in, pdf); | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-07 17:32:01 +00:00
										 |  |  | 	if(*pdf != 0.0f) { | 
					
						
							|  |  |  | 		bsdf_eval_init(bsdf_eval, sc->type, eval*sc->weight, kernel_data.film.use_light_pass); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-07 17:32:01 +00:00
										 |  |  | 		if(sd->num_closure > 1) { | 
					
						
							|  |  |  | 			float sweight = sc->sample_weight; | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 			_shader_bsdf_multi_eval(kg, sd, *omega_in, pdf, sampled, bsdf_eval, *pdf*sweight, sweight); | 
					
						
							| 
									
										
										
										
											2012-02-07 17:32:01 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return label; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device int shader_bsdf_sample_closure(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2012-06-13 11:44:48 +00:00
										 |  |  | 	const ShaderClosure *sc, float randu, float randv, BsdfEval *bsdf_eval, | 
					
						
							|  |  |  | 	float3 *omega_in, differential3 *domega_in, float *pdf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int label; | 
					
						
							|  |  |  | 	float3 eval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	*pdf = 0.0f; | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 	label = bsdf_sample(kg, sd, sc, randu, randv, &eval, omega_in, domega_in, pdf); | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-13 11:44:48 +00:00
										 |  |  | 	if(*pdf != 0.0f) | 
					
						
							|  |  |  | 		bsdf_eval_init(bsdf_eval, sc->type, eval*sc->weight, kernel_data.film.use_light_pass); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return label; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_bsdf_blur(KernelGlobals *kg, ShaderData *sd, float roughness) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 		if(CLOSURE_IS_BSDF(sc->type)) | 
					
						
							|  |  |  | 			bsdf_blur(kg, sc, roughness); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_transparency(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-05-26 12:50:57 +02:00
										 |  |  | 	if(sd->flag & SD_HAS_ONLY_VOLUME) | 
					
						
							|  |  |  | 		return make_float3(1.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 		if(sc->type == CLOSURE_BSDF_TRANSPARENT_ID) // todo: make this work for osl
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 			eval += sc->weight; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_alpha(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
										
											2013-09-17 13:22:42 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 alpha = make_float3(1.0f, 1.0f, 1.0f) - shader_bsdf_transparency(kg, sd); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	alpha = max(alpha, make_float3(0.0f, 0.0f, 0.0f)); | 
					
						
							|  |  |  | 	alpha = min(alpha, make_float3(1.0f, 1.0f, 1.0f)); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return alpha; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_diffuse(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSDF_DIFFUSE(sc->type)) | 
					
						
							|  |  |  | 			eval += sc->weight; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_glossy(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSDF_GLOSSY(sc->type)) | 
					
						
							|  |  |  | 			eval += sc->weight; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_transmission(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSDF_TRANSMISSION(sc->type)) | 
					
						
							|  |  |  | 			eval += sc->weight; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_subsurface(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
										
											2013-08-03 13:12:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSSRDF(sc->type)) | 
					
						
							|  |  |  | 			eval += sc->weight; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bsdf_ao(KernelGlobals *kg, ShaderData *sd, float ao_factor, float3 *N_) | 
					
						
							| 
									
										
										
										
											2012-11-06 19:59:02 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 	float3 N = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2012-11-15 15:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-06 19:59:02 +00:00
										 |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-15 15:37:58 +00:00
										 |  |  | 		if(CLOSURE_IS_BSDF_DIFFUSE(sc->type)) { | 
					
						
							|  |  |  | 			eval += sc->weight*ao_factor; | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 			N += sc->N*average(sc->weight); | 
					
						
							| 
									
										
										
										
											2012-11-15 15:37:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-08-14 19:38:14 +00:00
										 |  |  | 		else if(CLOSURE_IS_AMBIENT_OCCLUSION(sc->type)) { | 
					
						
							| 
									
										
										
										
											2012-11-06 19:59:02 +00:00
										 |  |  | 			eval += sc->weight; | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 			N += sd->N*average(sc->weight); | 
					
						
							| 
									
										
										
										
											2012-11-15 15:37:58 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-11-06 19:59:02 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 	if(is_zero(N)) | 
					
						
							|  |  |  | 		N = sd->N; | 
					
						
							| 
									
										
										
										
											2012-11-23 13:41:25 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 		N = normalize(N); | 
					
						
							| 
									
										
										
										
											2012-11-15 15:37:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | 	*N_ = N; | 
					
						
							| 
									
										
										
										
											2012-11-06 19:59:02 +00:00
										 |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_bssrdf_sum(ShaderData *sd, float3 *N_, float *texture_blur_) | 
					
						
							| 
									
										
										
										
											2013-08-18 14:15:57 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 	float3 N = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 	float texture_blur = 0.0f, weight_sum = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_BSSRDF(sc->type)) { | 
					
						
							|  |  |  | 			float avg_weight = fabsf(average(sc->weight)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			N += sc->N*avg_weight; | 
					
						
							|  |  |  | 			eval += sc->weight; | 
					
						
							|  |  |  | 			texture_blur += sc->data1*avg_weight; | 
					
						
							|  |  |  | 			weight_sum += avg_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(N_) | 
					
						
							|  |  |  | 		*N_ = (is_zero(N))? sd->N: normalize(N); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(texture_blur_) | 
					
						
							|  |  |  | 		*texture_blur_ = texture_blur/weight_sum; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | /* Emission */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 emissive_eval(KernelGlobals *kg, ShaderData *sd, ShaderClosure *sc) | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return emissive_simple_eval(sd->Ng, sd->I); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_emissive_eval(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 	float3 eval; | 
					
						
							|  |  |  | 	eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i < sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 		if(CLOSURE_IS_EMISSION(sc->type)) | 
					
						
							|  |  |  | 			eval += emissive_eval(kg, sd, sc)*sc->weight; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return eval; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-28 13:55:59 +00:00
										 |  |  | /* Holdout */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_holdout_eval(KernelGlobals *kg, ShaderData *sd) | 
					
						
							| 
									
										
										
										
											2011-08-28 13:55:59 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	float3 weight = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for(int i = 0; i < sd->num_closure; i++) { | 
					
						
							|  |  |  | 		ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(CLOSURE_IS_HOLDOUT(sc->type)) | 
					
						
							|  |  |  | 			weight += sc->weight; | 
					
						
							| 
									
										
										
										
											2011-08-28 13:55:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return weight; | 
					
						
							| 
									
										
										
										
											2011-08-28 13:55:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* Surface Evaluation */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_eval_surface(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 	float randb, int path_flag, ShaderContext ctx) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	sd->num_closure = 0; | 
					
						
							|  |  |  | 	sd->randb_closure = randb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #ifdef __OSL__
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	if(kg->osl) | 
					
						
							|  |  |  | 		OSLShader::eval_surface(kg, sd, path_flag, ctx); | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	else | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __SVM__
 | 
					
						
							| 
									
										
										
										
											2014-04-21 15:53:20 +02:00
										 |  |  | 		svm_eval_nodes(kg, sd, SHADER_TYPE_SURFACE, path_flag); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 		sd->closure.weight = make_float3(0.8f, 0.8f, 0.8f); | 
					
						
							| 
									
										
										
										
											2013-05-09 14:05:40 +00:00
										 |  |  | 		sd->closure.N = sd->N; | 
					
						
							|  |  |  | 		sd->flag |= bsdf_diffuse_setup(&sd->closure); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Background Evaluation */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device float3 shader_eval_background(KernelGlobals *kg, ShaderData *sd, int path_flag, ShaderContext ctx) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	sd->num_closure = 0; | 
					
						
							|  |  |  | 	sd->randb_closure = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #ifdef __OSL__
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	if(kg->osl) { | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 		return OSLShader::eval_background(kg, sd, path_flag, ctx); | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	else | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #ifdef __SVM__
 | 
					
						
							| 
									
										
										
										
											2014-04-21 15:53:20 +02:00
										 |  |  | 		svm_eval_nodes(kg, sd, SHADER_TYPE_SURFACE, path_flag); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 		float3 eval = make_float3(0.0f, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 		for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							|  |  |  | 			const ShaderClosure *sc = &sd->closure[i]; | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 			if(CLOSURE_IS_BACKGROUND(sc->type)) | 
					
						
							|  |  |  | 				eval += sc->weight; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 		return eval; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 		return make_float3(0.8f, 0.8f, 0.8f); | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Volume */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | #ifdef __VOLUME__
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | ccl_device_inline void _shader_volume_phase_multi_eval(const ShaderData *sd, const float3 omega_in, float *pdf, | 
					
						
							|  |  |  | 	int skip_phase, BsdfEval *result_eval, float sum_pdf, float sum_sample_weight) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 	for(int i = 0; i< sd->num_closure; i++) { | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | 		if(i == skip_phase) | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 		const ShaderClosure *sc = &sd->closure[i]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | 		if(CLOSURE_IS_PHASE(sc->type)) { | 
					
						
							|  |  |  | 			float phase_pdf = 0.0f; | 
					
						
							|  |  |  | 			float3 eval = volume_phase_eval(sd, sc, omega_in, &phase_pdf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if(phase_pdf != 0.0f) { | 
					
						
							|  |  |  | 				bsdf_eval_accum(result_eval, sc->type, eval); | 
					
						
							| 
									
										
										
										
											2014-04-04 16:45:49 +02:00
										 |  |  | 				sum_pdf += phase_pdf*sc->sample_weight; | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			sum_sample_weight += sc->sample_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | 	*pdf = (sum_sample_weight > 0.0f)? sum_pdf/sum_sample_weight: 0.0f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ccl_device void shader_volume_phase_eval(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							|  |  |  | 	const float3 omega_in, BsdfEval *eval, float *pdf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bsdf_eval_init(eval, NBUILTIN_CLOSURES, make_float3(0.0f, 0.0f, 0.0f), kernel_data.film.use_light_pass); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_shader_volume_phase_multi_eval(sd, omega_in, pdf, -1, eval, 0.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | ccl_device int shader_volume_phase_sample(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							|  |  |  | 	float randu, float randv, BsdfEval *phase_eval, | 
					
						
							|  |  |  | 	float3 *omega_in, differential3 *domega_in, float *pdf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int sampled = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(sd->num_closure > 1) { | 
					
						
							|  |  |  | 		/* pick a phase closure based on sample weights */ | 
					
						
							|  |  |  | 		float sum = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(sampled = 0; sampled < sd->num_closure; sampled++) { | 
					
						
							|  |  |  | 			const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(CLOSURE_IS_PHASE(sc->type)) | 
					
						
							|  |  |  | 				sum += sc->sample_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		float r = sd->randb_closure*sum; | 
					
						
							|  |  |  | 		sum = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for(sampled = 0; sampled < sd->num_closure; sampled++) { | 
					
						
							|  |  |  | 			const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if(CLOSURE_IS_PHASE(sc->type)) { | 
					
						
							|  |  |  | 				sum += sc->sample_weight; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if(r <= sum) | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(sampled == sd->num_closure) { | 
					
						
							|  |  |  | 			*pdf = 0.0f; | 
					
						
							|  |  |  | 			return LABEL_NONE; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* todo: this isn't quite correct, we don't weight anisotropy properly
 | 
					
						
							|  |  |  | 	 * depending on color channels, even if this is perhaps not a common case */ | 
					
						
							|  |  |  | 	const ShaderClosure *sc = &sd->closure[sampled]; | 
					
						
							|  |  |  | 	int label; | 
					
						
							|  |  |  | 	float3 eval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	*pdf = 0.0f; | 
					
						
							|  |  |  | 	label = volume_phase_sample(sd, sc, randu, randv, &eval, omega_in, domega_in, pdf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(*pdf != 0.0f) { | 
					
						
							|  |  |  | 		bsdf_eval_init(phase_eval, sc->type, eval, kernel_data.film.use_light_pass); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return label; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ccl_device int shader_phase_sample_closure(KernelGlobals *kg, const ShaderData *sd, | 
					
						
							|  |  |  | 	const ShaderClosure *sc, float randu, float randv, BsdfEval *phase_eval, | 
					
						
							|  |  |  | 	float3 *omega_in, differential3 *domega_in, float *pdf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int label; | 
					
						
							|  |  |  | 	float3 eval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	*pdf = 0.0f; | 
					
						
							|  |  |  | 	label = volume_phase_sample(sd, sc, randu, randv, &eval, omega_in, domega_in, pdf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(*pdf != 0.0f) | 
					
						
							|  |  |  | 		bsdf_eval_init(phase_eval, sc->type, eval, kernel_data.film.use_light_pass); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return label; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* Volume Evaluation */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_eval_volume(KernelGlobals *kg, ShaderData *sd, | 
					
						
							| 
									
										
										
										
											2013-12-29 15:40:43 +01:00
										 |  |  | 	VolumeStack *stack, int path_flag, ShaderContext ctx) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	/* reset closures once at the start, we will be accumulating the closures
 | 
					
						
							|  |  |  | 	 * for all volumes in the stack into a single array of closures */ | 
					
						
							|  |  |  | 	sd->num_closure = 0; | 
					
						
							| 
									
										
										
										
											2013-12-28 23:00:51 +01:00
										 |  |  | 	sd->flag = 0; | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 	for(int i = 0; stack[i].shader != SHADER_NONE; i++) { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 		/* setup shaderdata from stack. it's mostly setup already in
 | 
					
						
							|  |  |  | 		 * shader_setup_from_volume, this switching should be quick */ | 
					
						
							|  |  |  | 		sd->object = stack[i].object; | 
					
						
							|  |  |  | 		sd->shader = stack[i].shader; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		sd->flag &= ~(SD_SHADER_FLAGS|SD_OBJECT_FLAGS); | 
					
						
							|  |  |  | 		sd->flag |= kernel_tex_fetch(__shader_flag, (sd->shader & SHADER_MASK)*2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:47 +01:00
										 |  |  | 		if(sd->object != OBJECT_NONE) { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 			sd->flag |= kernel_tex_fetch(__object_flag, sd->object); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __OBJECT_MOTION__
 | 
					
						
							|  |  |  | 			/* todo: this is inefficient for motion blur, we should be
 | 
					
						
							|  |  |  | 			 * caching matrices instead of recomputing them each step */ | 
					
						
							|  |  |  | 			shader_setup_object_transforms(kg, sd, sd->time); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* evaluate shader */ | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #ifdef __SVM__
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #ifdef __OSL__
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 		if(kg->osl) { | 
					
						
							|  |  |  | 			OSLShader::eval_volume(kg, sd, path_flag, ctx); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-04-21 15:53:20 +02:00
										 |  |  | 			svm_eval_nodes(kg, sd, SHADER_TYPE_VOLUME, path_flag); | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* merge closures to avoid exceeding number of closures limit */ | 
					
						
							|  |  |  | 		if(i > 0) | 
					
						
							|  |  |  | 			shader_merge_closures(sd); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 15:48:04 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* Displacement Evaluation */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device void shader_eval_displacement(KernelGlobals *kg, ShaderData *sd, ShaderContext ctx) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	sd->num_closure = 0; | 
					
						
							|  |  |  | 	sd->randb_closure = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	/* this will modify sd->P */ | 
					
						
							|  |  |  | #ifdef __SVM__
 | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #ifdef __OSL__
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	if(kg->osl) | 
					
						
							| 
									
										
										
										
											2012-12-15 10:18:42 +00:00
										 |  |  | 		OSLShader::eval_displacement(kg, sd, ctx); | 
					
						
							| 
									
										
										
										
											2012-09-03 13:56:40 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2011-09-12 13:13:56 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2014-04-21 15:53:20 +02:00
										 |  |  | 		svm_eval_nodes(kg, sd, SHADER_TYPE_DISPLACEMENT, 0); | 
					
						
							| 
									
										
										
										
											2013-12-28 20:02:40 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | /* Transparent Shadows */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __TRANSPARENT_SHADOWS__
 | 
					
						
							| 
									
										
										
										
											2013-11-16 00:17:10 +01:00
										 |  |  | ccl_device bool shader_transparent_shadow(KernelGlobals *kg, Intersection *isect) | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int prim = kernel_tex_fetch(__prim_index, isect->prim); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 	int shader = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __HAIR__
 | 
					
						
							| 
									
										
										
										
											2014-03-29 13:03:46 +01:00
										 |  |  | 	if(kernel_tex_fetch(__prim_type, isect->prim) & PRIMITIVE_ALL_TRIANGLE) { | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-06-13 21:27:21 +02:00
										 |  |  | 		shader = __float_as_int(kernel_tex_fetch(__tri_shader, prim)); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | #ifdef __HAIR__
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2013-01-03 12:09:09 +00:00
										 |  |  | 		float4 str = kernel_tex_fetch(__curves, prim); | 
					
						
							| 
									
										
										
										
											2012-12-28 14:21:30 +00:00
										 |  |  | 		shader = __float_as_int(str.z); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
											
												Cycles: Render Passes
Currently supported passes:
* Combined, Z, Normal, Object Index, Material Index, Emission, Environment,
  Diffuse/Glossy/Transmission x Direct/Indirect/Color
Not supported yet:
* UV, Vector, Mist
Only enabled for CPU devices at the moment, will do GPU tweaks tommorrow,
also for environment importance sampling.
Documentation:
http://wiki.blender.org/index.php/Doc:2.6/Manual/Render/Cycles/Passes
											
										 
											2012-01-25 17:23:52 +00:00
										 |  |  | 	int flag = kernel_tex_fetch(__shader_flag, (shader & SHADER_MASK)*2); | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-18 09:36:00 +00:00
										 |  |  | 	return (flag & SD_HAS_TRANSPARENT_SHADOW) != 0; | 
					
						
							| 
									
										
										
										
											2011-09-27 20:37:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | CCL_NAMESPACE_END | 
					
						
							|  |  |  | 
 |