From 7057048da594448a1c287bd04ff28e1e14c5672e Mon Sep 17 00:00:00 2001 From: Carlos Lopez Date: Sat, 26 Oct 2024 20:19:59 -0400 Subject: [PATCH] perf(shader): optimize hue correction --- src/shaders/colorcorrect.hlsl | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/src/shaders/colorcorrect.hlsl b/src/shaders/colorcorrect.hlsl index 6d80760c..887ae6af 100644 --- a/src/shaders/colorcorrect.hlsl +++ b/src/shaders/colorcorrect.hlsl @@ -53,21 +53,20 @@ float3 Hue(float3 incorrect_color, float3 correct_color, float strength = 1.f) { if (strength == 0.f) return incorrect_color; float3 correct_lab = renodx::color::oklab::from::BT709(correct_color); - float3 correct_lch = renodx::color::oklch::from::OkLab(correct_lab); float3 incorrect_lab = renodx::color::oklab::from::BT709(incorrect_color); - float3 incorrect_lch = renodx::color::oklch::from::OkLab(incorrect_lab); - if (strength == 1.f) { - incorrect_lch[2] = correct_lch[2]; - } else { - float old_chroma = incorrect_lch[1]; - - incorrect_lab.yz = lerp(incorrect_lab.yz, correct_lab.yz, strength); - incorrect_lch = renodx::color::oklch::from::OkLab(incorrect_lab); - incorrect_lch[1] = old_chroma; + + float chrominance_pre_adjust = distance(incorrect_lab.yz, 0); + + incorrect_lab.yz = lerp(incorrect_lab.yz, correct_lab.yz, strength); + + float chrominance_post_adjust = distance(incorrect_lab.yz, 0); + + if (chrominance_post_adjust != 0.f) { + incorrect_lab.yz *= chrominance_pre_adjust / chrominance_post_adjust; } - float3 color = renodx::color::bt709::from::OkLCh(incorrect_lch); + float3 color = renodx::color::bt709::from::OkLab(incorrect_lab); color = renodx::color::bt709::clamp::AP1(color); return color; }