StackGenVis: Alignment of Data, Algorithms, and Models for Stacking Ensemble Learning Using Performance Metrics https://doi.org/10.1109/TVCG.2020.3030352
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
StackGenVis/frontend/node_modules/glsl-specular-beckmann
Angelos Chatzimparmpas f521a3509d paper-version 4 years ago
..
example paper-version 4 years ago
.npmignore paper-version 4 years ago
LICENSE paper-version 4 years ago
README.md paper-version 4 years ago
distribution.glsl paper-version 4 years ago
index.glsl paper-version 4 years ago
package.json paper-version 4 years ago

README.md

glsl-specular-beckmann

Computes the specular power from the Beckmann distribution

Example

#pragma glslify: beckmann = require(glsl-specular-beckmann)

uniform vec3 eyePosition;
uniform vec3 lightPosition;

uniform float roughness;

varying vec3 surfacePosition;
varying vec3 surfaceNormal;

void main() {
  vec3 eyeDirection = normalize(eyePosition - surfacePosition);
  vec3 lightDirection = normalize(lightPosition - surfacePosition);
  vec3 normal = normalize(surfaceNormal);

  float power = beckmann(lightDirection, viewDirection, normal, roughness);

  gl_FragColor = vec4(power,power,power,1.0);
}

Usage

Install with npm:

npm install glsl-specular-beckmann

Then use with glslify.

API

#pragma glslify: beckmann = require(glsl-specular-beckmann)
float beckmann(vec3 lightDir, vec3 eyeDir, vec3 normal, float shininess)

Computes the specular power in the Beckmann model

  • lightDir is a unit length vec3 pointing from the surface point toward the light
  • eyeDir is a unit length vec3 pointing from the surface point toward the camera
  • normal is the surface normal at the sample point
  • roughness is a parameter between 0 and 1 measuring the surface roughness. Small values are shinier, larger values are rougher.

Returns A float representing the specular power

License

(c) 2014 Mikola Lysenko. MIT License