d3dshader: Fix gamma and primaries conversion pixel shader

Fixing regression introduced by the commit of f52ecb9607

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6803>
This commit is contained in:
Seungha Yang 2024-05-04 20:08:49 +09:00
parent e2679face1
commit 5e4a76fdf1
2 changed files with 105 additions and 122 deletions

View file

@ -548,24 +548,25 @@ class ConverterGamma : IConverter
{ {
float4 Execute (float4 sample) float4 Execute (float4 sample)
{ {
float3 rgb_space;
float3 out_space; float3 out_space;
out_space.x = dot (preCoeff.CoeffX, sample.xyz); rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = dot (preCoeff.CoeffY, sample.xyz); rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = dot (preCoeff.CoeffZ, sample.xyz); rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);
out_space += preCoeff.Offset; rgb_space += preCoeff.Offset;
out_space = clamp (out_space, preCoeff.Min, preCoeff.Max); rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);
out_space.x = gammaDecLUT.Sample (linearSampler, out_space.x); rgb_space.x = gammaDecLUT.Sample (linearSampler, rgb_space.x);
out_space.y = gammaDecLUT.Sample (linearSampler, out_space.y); rgb_space.y = gammaDecLUT.Sample (linearSampler, rgb_space.y);
out_space.z = gammaDecLUT.Sample (linearSampler, out_space.z); rgb_space.z = gammaDecLUT.Sample (linearSampler, rgb_space.z);
out_space.x = gammaEncLUT.Sample (linearSampler, out_space.x); rgb_space.x = gammaEncLUT.Sample (linearSampler, rgb_space.x);
out_space.y = gammaEncLUT.Sample (linearSampler, out_space.y); rgb_space.y = gammaEncLUT.Sample (linearSampler, rgb_space.y);
out_space.z = gammaEncLUT.Sample (linearSampler, out_space.z); rgb_space.z = gammaEncLUT.Sample (linearSampler, rgb_space.z);
out_space.x = dot (postCoeff.CoeffX, out_space); out_space.x = dot (postCoeff.CoeffX, rgb_space);
out_space.y = dot (postCoeff.CoeffY, out_space); out_space.y = dot (postCoeff.CoeffY, rgb_space);
out_space.z = dot (postCoeff.CoeffZ, out_space); out_space.z = dot (postCoeff.CoeffZ, rgb_space);
out_space += postCoeff.Offset; out_space += postCoeff.Offset;
return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a); return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);
} }
@ -575,29 +576,31 @@ class ConverterPrimary : IConverter
{ {
float4 Execute (float4 sample) float4 Execute (float4 sample)
{ {
float3 rgb_space;
float3 primary_converted;
float3 out_space; float3 out_space;
float3 tmp;
out_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = dot (preCoeff.CoeffZ, sample.xyz);
out_space += preCoeff.Offset;
out_space = clamp (out_space, preCoeff.Min, preCoeff.Max);
out_space.x = gammaDecLUT.Sample (linearSampler, out_space.x); rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = gammaDecLUT.Sample (linearSampler, out_space.y); rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = gammaDecLUT.Sample (linearSampler, out_space.z); rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);
rgb_space += preCoeff.Offset;
rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);
tmp.x = dot (primariesCoeff.CoeffX, out_space); rgb_space.x = gammaDecLUT.Sample (linearSampler, rgb_space.x);
tmp.y = dot (primariesCoeff.CoeffY, out_space); rgb_space.y = gammaDecLUT.Sample (linearSampler, rgb_space.y);
tmp.z = dot (primariesCoeff.CoeffZ, out_space); rgb_space.z = gammaDecLUT.Sample (linearSampler, rgb_space.z);
out_space.x = gammaEncLUT.Sample (linearSampler, tmp.x); primary_converted.x = dot (primariesCoeff.CoeffX, rgb_space);
out_space.y = gammaEncLUT.Sample (linearSampler, tmp.y); primary_converted.y = dot (primariesCoeff.CoeffY, rgb_space);
out_space.z = gammaEncLUT.Sample (linearSampler, tmp.z); primary_converted.z = dot (primariesCoeff.CoeffZ, rgb_space);
out_space.x = dot (postCoeff.CoeffX, out_space); rgb_space.x = gammaEncLUT.Sample (linearSampler, primary_converted.x);
out_space.y = dot (postCoeff.CoeffY, out_space); rgb_space.y = gammaEncLUT.Sample (linearSampler, primary_converted.y);
out_space.z = dot (postCoeff.CoeffZ, out_space); rgb_space.z = gammaEncLUT.Sample (linearSampler, primary_converted.z);
out_space.x = dot (postCoeff.CoeffX, rgb_space);
out_space.y = dot (postCoeff.CoeffY, rgb_space);
out_space.z = dot (postCoeff.CoeffZ, rgb_space);
out_space += postCoeff.Offset; out_space += postCoeff.Offset;
return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a); return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);
} }
@ -1627,54 +1630,29 @@ static const char g_PSMain_converter_str[] =
" }\n" " }\n"
"};\n" "};\n"
"\n" "\n"
"class ConverterRange : IConverter\n"
"{\n"
" float4 Execute (float4 sample)\n"
" {\n"
" float3 out_space;\n"
" out_space.x = postCoeff.CoeffX.x * sample.x;\n"
" out_space.y = postCoeff.CoeffY.y * sample.y;\n"
" out_space.z = postCoeff.CoeffZ.z * sample.z;\n"
" out_space += postCoeff.Offset;\n"
" return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n"
" }\n"
"};\n"
"\n"
"class ConverterSimple : IConverter\n"
"{\n"
" float4 Execute (float4 sample)\n"
" {\n"
" float3 out_space;\n"
" out_space.x = dot (postCoeff.CoeffX, sample.xyz);\n"
" out_space.y = dot (postCoeff.CoeffY, sample.xyz);\n"
" out_space.z = dot (postCoeff.CoeffZ, sample.xyz);\n"
" out_space += postCoeff.Offset;\n"
" return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n"
" }\n"
"};\n"
"\n"
"class ConverterGamma : IConverter\n" "class ConverterGamma : IConverter\n"
"{\n" "{\n"
" float4 Execute (float4 sample)\n" " float4 Execute (float4 sample)\n"
" {\n" " {\n"
" float3 rgb_space;\n"
" float3 out_space;\n" " float3 out_space;\n"
" out_space.x = dot (preCoeff.CoeffX, sample.xyz);\n" " rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);\n"
" out_space.y = dot (preCoeff.CoeffY, sample.xyz);\n" " rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);\n"
" out_space.z = dot (preCoeff.CoeffZ, sample.xyz);\n" " rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);\n"
" out_space += preCoeff.Offset;\n" " rgb_space += preCoeff.Offset;\n"
" out_space = clamp (out_space, preCoeff.Min, preCoeff.Max);\n" " rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);\n"
"\n" "\n"
" out_space.x = gammaDecLUT.Sample (linearSampler, out_space.x);\n" " rgb_space.x = gammaDecLUT.Sample (linearSampler, rgb_space.x);\n"
" out_space.y = gammaDecLUT.Sample (linearSampler, out_space.y);\n" " rgb_space.y = gammaDecLUT.Sample (linearSampler, rgb_space.y);\n"
" out_space.z = gammaDecLUT.Sample (linearSampler, out_space.z);\n" " rgb_space.z = gammaDecLUT.Sample (linearSampler, rgb_space.z);\n"
"\n" "\n"
" out_space.x = gammaEncLUT.Sample (linearSampler, out_space.x);\n" " rgb_space.x = gammaEncLUT.Sample (linearSampler, rgb_space.x);\n"
" out_space.y = gammaEncLUT.Sample (linearSampler, out_space.y);\n" " rgb_space.y = gammaEncLUT.Sample (linearSampler, rgb_space.y);\n"
" out_space.z = gammaEncLUT.Sample (linearSampler, out_space.z);\n" " rgb_space.z = gammaEncLUT.Sample (linearSampler, rgb_space.z);\n"
"\n" "\n"
" out_space.x = dot (postCoeff.CoeffX, out_space);\n" " out_space.x = dot (postCoeff.CoeffX, rgb_space);\n"
" out_space.y = dot (postCoeff.CoeffY, out_space);\n" " out_space.y = dot (postCoeff.CoeffY, rgb_space);\n"
" out_space.z = dot (postCoeff.CoeffZ, out_space);\n" " out_space.z = dot (postCoeff.CoeffZ, rgb_space);\n"
" out_space += postCoeff.Offset;\n" " out_space += postCoeff.Offset;\n"
" return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n" " return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n"
" }\n" " }\n"
@ -1684,29 +1662,31 @@ static const char g_PSMain_converter_str[] =
"{\n" "{\n"
" float4 Execute (float4 sample)\n" " float4 Execute (float4 sample)\n"
" {\n" " {\n"
" float3 rgb_space;\n"
" float3 primary_converted;\n"
" float3 out_space;\n" " float3 out_space;\n"
" float3 tmp;\n"
" out_space.x = dot (preCoeff.CoeffX, sample.xyz);\n"
" out_space.y = dot (preCoeff.CoeffY, sample.xyz);\n"
" out_space.z = dot (preCoeff.CoeffZ, sample.xyz);\n"
" out_space += preCoeff.Offset;\n"
" out_space = clamp (out_space, preCoeff.Min, preCoeff.Max);\n"
"\n" "\n"
" out_space.x = gammaDecLUT.Sample (linearSampler, out_space.x);\n" " rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);\n"
" out_space.y = gammaDecLUT.Sample (linearSampler, out_space.y);\n" " rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);\n"
" out_space.z = gammaDecLUT.Sample (linearSampler, out_space.z);\n" " rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);\n"
" rgb_space += preCoeff.Offset;\n"
" rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);\n"
"\n" "\n"
" tmp.x = dot (primariesCoeff.CoeffX, out_space);\n" " rgb_space.x = gammaDecLUT.Sample (linearSampler, rgb_space.x);\n"
" tmp.y = dot (primariesCoeff.CoeffY, out_space);\n" " rgb_space.y = gammaDecLUT.Sample (linearSampler, rgb_space.y);\n"
" tmp.z = dot (primariesCoeff.CoeffZ, out_space);\n" " rgb_space.z = gammaDecLUT.Sample (linearSampler, rgb_space.z);\n"
"\n" "\n"
" out_space.x = gammaEncLUT.Sample (linearSampler, tmp.x);\n" " primary_converted.x = dot (primariesCoeff.CoeffX, rgb_space);\n"
" out_space.y = gammaEncLUT.Sample (linearSampler, tmp.y);\n" " primary_converted.y = dot (primariesCoeff.CoeffY, rgb_space);\n"
" out_space.z = gammaEncLUT.Sample (linearSampler, tmp.z);\n" " primary_converted.z = dot (primariesCoeff.CoeffZ, rgb_space);\n"
"\n" "\n"
" out_space.x = dot (postCoeff.CoeffX, out_space);\n" " rgb_space.x = gammaEncLUT.Sample (linearSampler, primary_converted.x);\n"
" out_space.y = dot (postCoeff.CoeffY, out_space);\n" " rgb_space.y = gammaEncLUT.Sample (linearSampler, primary_converted.y);\n"
" out_space.z = dot (postCoeff.CoeffZ, out_space);\n" " rgb_space.z = gammaEncLUT.Sample (linearSampler, primary_converted.z);\n"
"\n"
" out_space.x = dot (postCoeff.CoeffX, rgb_space);\n"
" out_space.y = dot (postCoeff.CoeffY, rgb_space);\n"
" out_space.z = dot (postCoeff.CoeffZ, rgb_space);\n"
" out_space += postCoeff.Offset;\n" " out_space += postCoeff.Offset;\n"
" return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n" " return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);\n"
" }\n" " }\n"

View file

@ -486,24 +486,25 @@ class ConverterGamma : IConverter
{ {
float4 Execute (float4 sample) float4 Execute (float4 sample)
{ {
float3 rgb_space;
float3 out_space; float3 out_space;
out_space.x = dot (preCoeff.CoeffX, sample.xyz); rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = dot (preCoeff.CoeffY, sample.xyz); rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = dot (preCoeff.CoeffZ, sample.xyz); rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);
out_space += preCoeff.Offset; rgb_space += preCoeff.Offset;
out_space = clamp (out_space, preCoeff.Min, preCoeff.Max); rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);
out_space.x = gammaDecLUT.Sample (lutSamplerState, out_space.x); rgb_space.x = gammaDecLUT.Sample (lutSamplerState, rgb_space.x);
out_space.y = gammaDecLUT.Sample (lutSamplerState, out_space.y); rgb_space.y = gammaDecLUT.Sample (lutSamplerState, rgb_space.y);
out_space.z = gammaDecLUT.Sample (lutSamplerState, out_space.z); rgb_space.z = gammaDecLUT.Sample (lutSamplerState, rgb_space.z);
out_space.x = gammaEncLUT.Sample (lutSamplerState, out_space.x); rgb_space.x = gammaEncLUT.Sample (lutSamplerState, rgb_space.x);
out_space.y = gammaEncLUT.Sample (lutSamplerState, out_space.y); rgb_space.y = gammaEncLUT.Sample (lutSamplerState, rgb_space.y);
out_space.z = gammaEncLUT.Sample (lutSamplerState, out_space.z); rgb_space.z = gammaEncLUT.Sample (lutSamplerState, rgb_space.z);
out_space.x = dot (postCoeff.CoeffX, out_space); out_space.x = dot (postCoeff.CoeffX, rgb_space);
out_space.y = dot (postCoeff.CoeffY, out_space); out_space.y = dot (postCoeff.CoeffY, rgb_space);
out_space.z = dot (postCoeff.CoeffZ, out_space); out_space.z = dot (postCoeff.CoeffZ, rgb_space);
out_space += postCoeff.Offset; out_space += postCoeff.Offset;
return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a); return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);
} }
@ -513,29 +514,31 @@ class ConverterPrimary : IConverter
{ {
float4 Execute (float4 sample) float4 Execute (float4 sample)
{ {
float3 rgb_space;
float3 primary_converted;
float3 out_space; float3 out_space;
float3 tmp;
out_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = dot (preCoeff.CoeffZ, sample.xyz);
out_space += preCoeff.Offset;
out_space = clamp (out_space, preCoeff.Min, preCoeff.Max);
out_space.x = gammaDecLUT.Sample (lutSamplerState, out_space.x); rgb_space.x = dot (preCoeff.CoeffX, sample.xyz);
out_space.y = gammaDecLUT.Sample (lutSamplerState, out_space.y); rgb_space.y = dot (preCoeff.CoeffY, sample.xyz);
out_space.z = gammaDecLUT.Sample (lutSamplerState, out_space.z); rgb_space.z = dot (preCoeff.CoeffZ, sample.xyz);
rgb_space += preCoeff.Offset;
rgb_space = clamp (rgb_space, preCoeff.Min, preCoeff.Max);
tmp.x = dot (primariesCoeff.CoeffX, out_space); rgb_space.x = gammaDecLUT.Sample (lutSamplerState, rgb_space.x);
tmp.y = dot (primariesCoeff.CoeffY, out_space); rgb_space.y = gammaDecLUT.Sample (lutSamplerState, rgb_space.y);
tmp.z = dot (primariesCoeff.CoeffZ, out_space); rgb_space.z = gammaDecLUT.Sample (lutSamplerState, rgb_space.z);
out_space.x = gammaEncLUT.Sample (lutSamplerState, tmp.x); primary_converted.x = dot (primariesCoeff.CoeffX, rgb_space);
out_space.y = gammaEncLUT.Sample (lutSamplerState, tmp.y); primary_converted.y = dot (primariesCoeff.CoeffY, rgb_space);
out_space.z = gammaEncLUT.Sample (lutSamplerState, tmp.z); primary_converted.z = dot (primariesCoeff.CoeffZ, rgb_space);
out_space.x = dot (postCoeff.CoeffX, out_space); rgb_space.x = gammaEncLUT.Sample (lutSamplerState, primary_converted.x);
out_space.y = dot (postCoeff.CoeffY, out_space); rgb_space.y = gammaEncLUT.Sample (lutSamplerState, primary_converted.y);
out_space.z = dot (postCoeff.CoeffZ, out_space); rgb_space.z = gammaEncLUT.Sample (lutSamplerState, primary_converted.z);
out_space.x = dot (postCoeff.CoeffX, rgb_space);
out_space.y = dot (postCoeff.CoeffY, rgb_space);
out_space.z = dot (postCoeff.CoeffZ, rgb_space);
out_space += postCoeff.Offset; out_space += postCoeff.Offset;
return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a); return float4 (clamp (out_space, postCoeff.Min, postCoeff.Max), sample.a);
} }