getIBLIndirect: "\n// struct IBLIndirect {\n// diffuse: vec3f,\n// specular: vec3f\n// }\n\nfn getIBLIndirect(\n normal: vec3f,\n viewDirection: vec3f,\n roughness: f32,\n metallic: f32,\n diffuseColor: vec3f,\n f0: vec3f,\n clampSampler: sampler,\n lutTexture: texture_2d<f32>,\n envSpecularTexture: texture_cube<f32>,\n envDiffuseTexture: texture_cube<f32>,\n ptr_reflectedLight: ptr<function, ReflectedLight>,\n // ptr_iblIndirect: ptr<function, IBLIndirect>\n) {\n let N: vec3f = normalize(normal);\n let V: vec3f = normalize(viewDirection);\n let NdotV: f32 = clamp(dot(N, V), 0.0, 1.0);\n \n let reflection: vec3f = normalize(reflect(-V, N));\n \n let iblDiffuseColor: vec3f = mix(diffuseColor, vec3(0.0), vec3(metallic));\n\n let brdfSamplePoint: vec2f = clamp(vec2(NdotV, roughness), vec2(0.0), vec2(1.0));\n \n let brdf: vec3f = textureSample(\n lutTexture,\n clampSampler,\n brdfSamplePoint\n ).rgb;\n\n let Fr: vec3f = max(vec3(1.0 - roughness), f0) - f0;\n let k_S: vec3f = f0 + Fr * pow(1.0 - NdotV, 5.0);\n var FssEss: vec3f = k_S * brdf.x + brdf.y;\n \n // IBL specular (radiance)\n let lod: f32 = roughness * f32(textureNumLevels(envSpecularTexture) - 1);\n \n let specularLight: vec4f = textureSampleLevel(\n envSpecularTexture,\n clampSampler,\n reflection * ibl.envRotation,\n lod\n );\n \n // IBL diffuse (irradiance)\n let diffuseLight: vec4f = textureSample(\n envDiffuseTexture,\n clampSampler,\n normal * ibl.envRotation\n );\n \n // product of specularFactor and specularTexture.a\n let specularWeight: f32 = 1.0;\n \n FssEss = specularWeight * k_S * brdf.x + brdf.y;\n \n let Ems: f32 = (1.0 - (brdf.x + brdf.y));\n let F_avg: vec3f = specularWeight * (f0 + (1.0 - f0) / 21.0);\n let FmsEms: vec3f = Ems * FssEss * F_avg / (1.0 - F_avg * Ems);\n let k_D: vec3f = iblDiffuseColor * (1.0 - FssEss + FmsEms);\n \n (*ptr_reflectedLight).indirectSpecular += specularLight.rgb * FssEss * ibl.specularStrength;\n (*ptr_reflectedLight).indirectDiffuse += (FmsEms + k_D) * diffuseLight.rgb * ibl.diffuseStrength;\n \n // (*ptr_iblIndirect).diffuse = PI * diffuseLight.rgb * ibl.diffuseStrength;\n // (*ptr_iblIndirect).specular = specularLight.rgb * ibl.specularStrength;\n}\n" = ...

Helper function chunk appended internally and used to compute IBL indirect light contributions, based on environment diffuse and specular maps. Image Based Lightning also use PBR direct light contributions.