24 lines
668 B
JavaScript
24 lines
668 B
JavaScript
import { tslFn } from '../../shadernode/ShaderNode.js';
|
||
|
||
// Microfacet Models for Refraction through Rough Surfaces - equation (33)
|
||
// http://graphicrants.blogspot.com/2013/08/specular-brdf-reference.html
|
||
// alpha is "roughness squared" in Disney’s reparameterization
|
||
const D_GGX = tslFn( ( { alpha, dotNH } ) => {
|
||
|
||
const a2 = alpha.pow2();
|
||
|
||
const denom = dotNH.pow2().mul( a2.oneMinus() ).oneMinus(); // avoid alpha = 0 with dotNH = 1
|
||
|
||
return a2.div( denom.pow2() ).mul( 1 / Math.PI );
|
||
|
||
} ).setLayout( {
|
||
name: 'D_GGX',
|
||
type: 'float',
|
||
inputs: [
|
||
{ name: 'alpha', type: 'float' },
|
||
{ name: 'dotNH', type: 'float' }
|
||
]
|
||
} ); // validated
|
||
|
||
export default D_GGX;
|