Skip to content

Commit

Permalink
re-implement fma
Browse files Browse the repository at this point in the history
  • Loading branch information
Xtarsia committed Oct 28, 2024
1 parent 32b3e06 commit 0d5dbc4
Showing 1 changed file with 4 additions and 4 deletions.
8 changes: 4 additions & 4 deletions src/shaders/main.glsl
Original file line number Diff line number Diff line change
Expand Up @@ -172,15 +172,15 @@ vec3 unpack_normal(vec4 rgba) {
}

vec3 pack_normal(vec3 n) {
return (n.xzy + 1.0) * 0.5;
return fma(n.xzy, vec3(0.5), vec3(0.5));
}

float random(in vec2 xy) {
return fract(sin(dot(xy, vec2(12.9898, 78.233))) * 43758.5453);
}

vec2 rotate(vec2 v, float cosa, float sina) {
return vec2(cosa * v.x - sina * v.y, sina * v.x + cosa * v.y);
return vec2(fma(cosa, v.x, - sina * v.y), fma(sina, v.x, cosa * v.y));
}

// Moves a point around a pivot point.
Expand All @@ -206,7 +206,7 @@ vec4 height_blend(vec4 a_value, float a_height, vec4 b_value, float b_height, fl
vec2 detiling(vec2 uv, vec2 uv_center, int mat_id, inout float normal_rotation){
if (_texture_detile_array[mat_id] >= 0.001){
uv_center = floor(uv_center) + 0.5;
float detile = (random(uv_center) - 0.5) * 2.0 * TAU * _texture_detile_array[mat_id]; // -180deg to 180deg
float detile = fma(random(uv_center), 2.0, -1.0) * TAU * _texture_detile_array[mat_id]; // -180deg to 180deg
uv = rotate_around(uv, uv_center, detile);
// Accumulate total rotation for normal rotation
normal_rotation += detile;
Expand All @@ -216,7 +216,7 @@ vec2 detiling(vec2 uv, vec2 uv_center, int mat_id, inout float normal_rotation){

vec2 rotate_normal(vec2 normal, float angle) {
float new_x = dot(vec2(cos(angle), sin(angle)), normal);
angle += PI * 0.5;
angle = fma(PI, 0.5, angle);
float new_y = dot(vec2(cos(angle), sin(angle)), normal);
return vec2(new_x, new_y);
}
Expand Down

0 comments on commit 0d5dbc4

Please sign in to comment.