Blender V5.0
kernel/svm/ies.h
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2011-2022 Blender Foundation
2 *
3 * SPDX-License-Identifier: Apache-2.0 */
4
5#pragma once
6
7#include "kernel/svm/util.h"
8
9#include "kernel/util/ies.h"
10
12
14 ccl_private ShaderData * /*sd*/,
15 ccl_private float *stack,
16 const uint4 node)
17{
18 uint vector_offset;
19 uint strength_offset;
20 uint fac_offset;
21 const uint slot = node.z;
22 svm_unpack_node_uchar3(node.y, &strength_offset, &vector_offset, &fac_offset);
23
24 float3 vector = stack_load_float3(stack, vector_offset);
25 const float strength = stack_load_float_default(stack, strength_offset, node.w);
26
28 const float v_angle = safe_acosf(-vector.z);
29 const float h_angle = atan2f(vector.x, vector.y) + M_PI_F;
30
31 const float fac = strength * kernel_ies_interp(kg, slot, h_angle, v_angle);
32
33 if (stack_valid(fac_offset)) {
34 stack_store_float(stack, fac_offset, fac);
35 }
36}
37
MINLINE float safe_acosf(float a)
unsigned int uint
ccl_device_inline void stack_store_float(ccl_private float *stack, const uint a, const float f)
ccl_device_inline float stack_load_float_default(const ccl_private float *stack, const uint a, const uint value)
ccl_device_forceinline void svm_unpack_node_uchar3(const uint i, ccl_private uint *x, ccl_private uint *y, ccl_private uint *z)
ccl_device_inline bool stack_valid(const uint a)
CCL_NAMESPACE_BEGIN ccl_device_inline float3 stack_load_float3(const ccl_private float *stack, const uint a)
#define ccl_private
const ThreadKernelGlobalsCPU * KernelGlobals
#define ccl_device_noinline
#define CCL_NAMESPACE_END
VecBase< float, D > normalize(VecOp< float, D >) RET
CCL_NAMESPACE_BEGIN ccl_device_noinline void svm_node_ies(KernelGlobals kg, ccl_private ShaderData *, ccl_private float *stack, const uint4 node)
ccl_device_inline float kernel_ies_interp(KernelGlobals kg, const int slot, const float h_angle, const float v_angle)
#define M_PI_F
#define atan2f
uint y
Definition types_uint4.h:13
uint z
Definition types_uint4.h:13
uint w
Definition types_uint4.h:13