Files
test2/source/blender/draw/engines/eevee/shaders/eevee_bxdf_lib.glsl
Clément Foucault fe213f80a4 GPU: Shader: Make info files generated
This is the first step of moving the create infos
back inside shader sources.

All info files are now treated as source files.
However, they are not considered in the include tree
yet. This will come in another following PR.

Each shader source file now generate a `.info` file
containing only the create info declarations.

This renames all info files so that they do not
conflict with their previous versions that were
copied (non-generated).

Pull Request: https://projects.blender.org/blender/blender/pulls/146676
2025-09-25 10:57:02 +02:00

87 lines
2.2 KiB
GLSL

/* SPDX-FileCopyrightText: 2023 Blender Authors
*
* SPDX-License-Identifier: GPL-2.0-or-later */
#pragma once
#include "infos/eevee_common_infos.hh"
/**
* BxDF evaluation functions.
*/
struct BsdfSample {
packed_float3 direction;
float pdf;
};
struct BsdfEval {
float throughput;
float pdf;
/* `throughput / pdf`. */
float weight;
};
struct ClosureLight {
/* LTC matrix. */
packed_float4 ltc_mat;
/* Shading normal. */
packed_float3 N;
/* Enum used as index to fetch which light intensity to use [0..3]. */
LightingType type;
/* Output both shadowed and unshadowed for shadow denoising. */
packed_float3 light_shadowed;
packed_float3 light_unshadowed;
METAL_CONSTRUCTOR_5(ClosureLight,
packed_float4,
ltc_mat,
packed_float3,
N,
LightingType,
type,
packed_float3,
light_shadowed,
packed_float3,
light_unshadowed)
static ClosureLight zero()
{
return ClosureLight(float4(0), float3(0), LIGHT_DIFFUSE, float3(0), float3(0));
}
};
/* Represent an approximation of a bunch of rays from a BSDF. */
struct LightProbeRay {
/* Average direction of sampled rays or its approximation.
* Magnitude will reduce directionality of spherical harmonic evaluation. */
packed_float3 dominant_direction;
/* Perceptual roughness in [0..1] range.
* Modulate blur level of spherical probe and blend between sphere probe and spherical harmonic
* evaluation at higher roughness. */
float perceptual_roughness;
};
/* -------------------------------------------------------------------- */
/** \name Utils
* \{ */
/* Fresnel monochromatic, perfect mirror */
float F_eta(float eta, float cos_theta)
{
/* Compute fresnel reflectance without explicitly computing
* the refracted direction. */
float c = abs(cos_theta);
float g = eta * eta - 1.0f + c * c;
if (g > 0.0f) {
g = sqrt(g);
float A = (g - c) / (g + c);
float B = (c * (g + c) - 1.0f) / (c * (g - c) + 1.0f);
return 0.5f * A * A * (1.0f + B * B);
}
/* Total internal reflections. */
return 1.0f;
}
/** \} */