7 uniform samplerCube environment_map;
9 vec2 hammersley(int i, int count)
11 float y = bitfieldReverse(uint(i))*2.3283064e-10;
12 return vec2(float(i)/count, y);
15 vec3 uv_to_hemisphere(float u, float v)
18 float r = sqrt(1.0-v*v);
19 return vec3(cos(phi)*r, sin(phi)*r, v);
22 vec3 ndist_ggxtr_importance_sample(vec2 uv, float roughness)
24 float rough_q = roughness*roughness;
26 float v = sqrt((1.0-uv.y)/(1.0+(rough_q-1.0)*uv.y));
27 return uv_to_hemisphere(uv.x, v);