diff options
author | Sergey Sharybin <sergey.vfx@gmail.com> | 2016-03-11 19:22:19 +0300 |
---|---|---|
committer | Sergey Sharybin <sergey.vfx@gmail.com> | 2016-03-12 13:01:20 +0300 |
commit | a8c87bad22e618fab19521b4e2d162d19946db98 (patch) | |
tree | ea238fb7064abad890c0f37833940fce9d3d00d6 /intern/cycles/kernel/kernel_camera.h | |
parent | e327fb522a8f6991d7cd537f4a7298559d08cff8 (diff) |
Cycles: Cleanup, spherical_stereo_direction will return normalized direction
Previously each call of this function was followed by a normaliztion, now it
is done in the function itself with an according note around the function.
Diffstat (limited to 'intern/cycles/kernel/kernel_camera.h')
-rw-r--r-- | intern/cycles/kernel/kernel_camera.h | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/intern/cycles/kernel/kernel_camera.h b/intern/cycles/kernel/kernel_camera.h index 6b8f18e3a21..db2f45ce096 100644 --- a/intern/cycles/kernel/kernel_camera.h +++ b/intern/cycles/kernel/kernel_camera.h @@ -109,7 +109,6 @@ ccl_device void camera_sample_perspective(KernelGlobals *kg, float raster_x, flo float3 tD = transform_direction(&cameratoworld, ray->D); ray->P = spherical_stereo_position(kg, tD, tP); ray->D = spherical_stereo_direction(kg, tD, tP, ray->P); - ray->D = normalize(ray->D); #ifdef __RAY_DIFFERENTIALS__ /* ray differential */ @@ -117,18 +116,18 @@ ccl_device void camera_sample_perspective(KernelGlobals *kg, float raster_x, flo tD = transform_direction(&cameratoworld, Pcamera); float3 Pdiff = spherical_stereo_position(kg, tD, Pcamera); - float3 Ddiff = normalize(spherical_stereo_direction(kg, tD, Pcamera, Pdiff)); + float3 Ddiff = spherical_stereo_direction(kg, tD, Pcamera, Pdiff); tP = transform_perspective(&rastertocamera, make_float3(raster_x + 1.0f, raster_y, 0.0f)); tD = transform_direction(&cameratoworld, tP); Pcamera = spherical_stereo_position(kg, tD, tP); - ray->dD.dx = normalize(spherical_stereo_direction(kg, tD, tP, Pcamera)) - Ddiff; + ray->dD.dx = spherical_stereo_direction(kg, tD, tP, Pcamera) - Ddiff; ray->dP.dx = Pcamera - Pdiff; tP = transform_perspective(&rastertocamera, make_float3(raster_x, raster_y + 1.0f, 0.0f)); tD = transform_direction(&cameratoworld, tP); Pcamera = spherical_stereo_position(kg, tD, tP); - ray->dD.dy = normalize(spherical_stereo_direction(kg, tD, tP, Pcamera)) - Ddiff; + ray->dD.dy = spherical_stereo_direction(kg, tD, tP, Pcamera) - Ddiff; /* dP.dy is zero, since the omnidirectional panorama only shift the eyes horizontally */ #endif @@ -276,7 +275,6 @@ ccl_device void camera_sample_panorama(KernelGlobals *kg, float raster_x, float float3 tD = transform_direction(&cameratoworld, ray->D); ray->P = spherical_stereo_position(kg, tD, tP); ray->D = spherical_stereo_direction(kg, tD, tP, ray->P); - ray->D = normalize(ray->D); #ifdef __RAY_DIFFERENTIALS__ /* ray differential */ @@ -285,18 +283,18 @@ ccl_device void camera_sample_panorama(KernelGlobals *kg, float raster_x, float tP = transform_perspective(&rastertocamera, make_float3(raster_x, raster_y, 0.0f)); tD = transform_direction(&cameratoworld, panorama_to_direction(kg, tP.x, tP.y)); float3 Pdiff = spherical_stereo_position(kg, tD, tP); - float3 Ddiff = normalize(spherical_stereo_direction(kg, tD, tP, Pdiff)); + float3 Ddiff = spherical_stereo_direction(kg, tD, tP, Pdiff); tP = transform_perspective(&rastertocamera, make_float3(raster_x + 1.0f, raster_y, 0.0f)); tD = transform_direction(&cameratoworld, panorama_to_direction(kg, tP.x, tP.y)); Pcamera = spherical_stereo_position(kg, tD, tP); - ray->dD.dx = normalize(spherical_stereo_direction(kg, tD, tP, Pcamera)) - Ddiff; + ray->dD.dx = spherical_stereo_direction(kg, tD, tP, Pcamera) - Ddiff; ray->dP.dx = Pcamera - Pdiff; tP = transform_perspective(&rastertocamera, make_float3(raster_x, raster_y + 1.0f, 0.0f)); tD = transform_direction(&cameratoworld, panorama_to_direction(kg, tP.x, tP.y)); Pcamera = spherical_stereo_position(kg, tD, tP); - ray->dD.dy = normalize(spherical_stereo_direction(kg, tD, tP, Pcamera)) - Ddiff; + ray->dD.dy = spherical_stereo_direction(kg, tD, tP, Pcamera) - Ddiff; /* dP.dy is zero, since the omnidirectional panorama only shift the eyes horizontally */ #endif } |