diff options
author | 2022-12-07 17:24:35 -0800 | |
---|---|---|
committer | 2023-01-19 02:05:35 +0000 | |
commit | 1107ff3272027f7a9a9924f7da9be2ecd5e616f7 (patch) | |
tree | 11e651960fc1b300af828d7c41283cd9481d8c8c /libs/jpegrecoverymap/recoverymapmath.cpp | |
parent | 1e057284468d048e4281709ba922303f8dbdb3ed (diff) |
jpegrecoverymap: clamp YUV to RGB conversion
Bug: 261877699
Test: push files from tests/data to /sdcard/Documents and then \
atest libjpegdecoder_test libjpegencoder_test libjpegrecoverymap_test
Change-Id: Id5c0e6846980c6ca4ff01726a1a09dfb9e95ee16
Diffstat (limited to 'libs/jpegrecoverymap/recoverymapmath.cpp')
-rw-r--r-- | libs/jpegrecoverymap/recoverymapmath.cpp | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/libs/jpegrecoverymap/recoverymapmath.cpp b/libs/jpegrecoverymap/recoverymapmath.cpp index 4a6feca2e8..7d29a3706e 100644 --- a/libs/jpegrecoverymap/recoverymapmath.cpp +++ b/libs/jpegrecoverymap/recoverymapmath.cpp @@ -70,6 +70,11 @@ void ShepardsIDW::fillShepardsIDW(float *weights, int incR, int incB) { //////////////////////////////////////////////////////////////////////////////// // sRGB transformations +static const float kMaxPixelFloat = 1.0f; +static float clampPixelFloat(float value) { + return (value < 0.0f) ? 0.0f : (value > kMaxPixelFloat) ? kMaxPixelFloat : value; +} + // See IEC 61966-2-1, Equation F.7. static const float kSrgbR = 0.2126f, kSrgbG = 0.7152f, kSrgbB = 0.0722f; @@ -81,9 +86,9 @@ float srgbLuminance(Color e) { static const float kSrgbRCr = 1.402f, kSrgbGCb = 0.34414f, kSrgbGCr = 0.71414f, kSrgbBCb = 1.772f; Color srgbYuvToRgb(Color e_gamma) { - return {{{ e_gamma.y + kSrgbRCr * e_gamma.v, - e_gamma.y - kSrgbGCb * e_gamma.u - kSrgbGCr * e_gamma.v, - e_gamma.y + kSrgbBCb * e_gamma.u }}}; + return {{{ clampPixelFloat(e_gamma.y + kSrgbRCr * e_gamma.v), + clampPixelFloat(e_gamma.y - kSrgbGCb * e_gamma.u - kSrgbGCr * e_gamma.v), + clampPixelFloat(e_gamma.y + kSrgbBCb * e_gamma.u) }}}; } // See ECMA TR/98, Section 7. @@ -169,9 +174,9 @@ static const float kBt2100GCb = kBt2100B * kBt2100Cb / kBt2100G; static const float kBt2100GCr = kBt2100R * kBt2100Cr / kBt2100G; Color bt2100YuvToRgb(Color e_gamma) { - return {{{ e_gamma.y + kBt2100Cr * e_gamma.v, - e_gamma.y - kBt2100GCb * e_gamma.u - kBt2100GCr * e_gamma.v, - e_gamma.y + kBt2100Cb * e_gamma.u }}}; + return {{{ clampPixelFloat(e_gamma.y + kBt2100Cr * e_gamma.v), + clampPixelFloat(e_gamma.y - kBt2100GCb * e_gamma.u - kBt2100GCr * e_gamma.v), + clampPixelFloat(e_gamma.y + kBt2100Cb * e_gamma.u) }}}; } // See ITU-R BT.2100-2, Table 5, HLG Reference OETF. |