2020-03-08 22:29:41 +00:00
|
|
|
float unormalize(uint value, int bits) {
|
|
|
|
const int range = (1 << bits) - 1;
|
|
|
|
|
|
|
|
return float(value) / float(range);
|
|
|
|
}
|
|
|
|
|
|
|
|
float snormalize(int value, int bits) {
|
|
|
|
const int range = (1 << (bits - 1)) - 1;
|
|
|
|
|
|
|
|
// Min because, -32 and -31 map to -1.0f, and we
|
|
|
|
// divide by 31.
|
2020-08-06 07:19:50 +01:00
|
|
|
return max(float(value) / float(range), -1.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
float unpackUnorm(uint p) {
|
|
|
|
return float(p) / 255.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
mat3x4 g_yuv_to_rgb = {
|
|
|
|
{ 298 / 256, 0, 409 / 256, 0.5 },
|
|
|
|
{ 298 / 256, -100 / 256, -208 / 256, 0.5 },
|
|
|
|
{ 298 / 256, 516 / 256, 0, 0.5 }
|
|
|
|
};
|
|
|
|
|
|
|
|
vec4 convertYUV(vec3 yuv) {
|
|
|
|
vec3 value = vec4(yuv, 1 / 255.0) * g_yuv_to_rgb;
|
|
|
|
|
|
|
|
return vec4(clamp(value, 0, 1), 1);
|
2020-08-07 09:37:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
mat3x3 g_bt703_to_rgb = {
|
|
|
|
{ 1.164, 0, 1.793 },
|
|
|
|
{ 1.164, -0.213, -0.533 },
|
|
|
|
{ 1.164, 2.112, 0 }
|
|
|
|
};
|
|
|
|
|
|
|
|
vec4 convertBT_703(vec3 cde) {
|
|
|
|
return vec4(clamp(cde * g_bt703_to_rgb, 0, 1), 1);
|
|
|
|
}
|