diff --git a/src/testapp/table.cpp b/src/testapp/table.cpp index a9bff864..9d0eaf20 100644 --- a/src/testapp/table.cpp +++ b/src/testapp/table.cpp @@ -76,13 +76,14 @@ const zimg::static_string_map g_matrix_table{ { "ictcp", MatrixCoefficients::REC_2100_ICTCP }, }; -const zimg::static_string_map g_transfer_table{ +const zimg::static_string_map g_transfer_table{ { "unspec", TransferCharacteristics::UNSPECIFIED }, { "linear", TransferCharacteristics::LINEAR }, { "log10", TransferCharacteristics::LOG_10 }, { "log316", TransferCharacteristics::LOG_SQRT }, { "240m", TransferCharacteristics::SMPTE_240M }, { "709", TransferCharacteristics::REC_709 }, + { "470bg", TransferCharacteristics::REC_470_BG }, { "xvycc", TransferCharacteristics::XVYCC }, { "srgb", TransferCharacteristics::SRGB }, { "st_2084", TransferCharacteristics::ST_2084 }, diff --git a/src/testapp/table.h b/src/testapp/table.h index e03bc6a1..65424832 100644 --- a/src/testapp/table.h +++ b/src/testapp/table.h @@ -37,7 +37,7 @@ class Filter; extern const zimg::static_string_map g_cpu_table; extern const zimg::static_string_map g_pixel_table; extern const zimg::static_string_map g_matrix_table; -extern const zimg::static_string_map g_transfer_table; +extern const zimg::static_string_map g_transfer_table; extern const zimg::static_string_map g_primaries_table; extern const zimg::static_string_map g_dither_table; extern const zimg::static_string_map(*)(double, double), 7> g_resize_table; diff --git a/src/zimg/api/zimg.cpp b/src/zimg/api/zimg.cpp index 3f18027a..fb6586af 100644 --- a/src/zimg/api/zimg.cpp +++ b/src/zimg/api/zimg.cpp @@ -250,11 +250,12 @@ zimg::colorspace::TransferCharacteristics translate_transfer(zimg_transfer_chara { using zimg::colorspace::TransferCharacteristics; - static SM_CONSTEXPR_14 const zimg::static_map map{ + static SM_CONSTEXPR_14 const zimg::static_map map{ { ZIMG_TRANSFER_709, TransferCharacteristics::REC_709 }, { ZIMG_TRANSFER_UNSPECIFIED, TransferCharacteristics::UNSPECIFIED }, { ZIMG_TRANSFER_240M, TransferCharacteristics::SMPTE_240M }, { ZIMG_TRANSFER_601, TransferCharacteristics::REC_709 }, + { ZIMG_TRANSFER_470BG, TransferCharacteristics::REC_470_BG }, { ZIMG_TRANSFER_IEC_61966_2_4, TransferCharacteristics::XVYCC }, { ZIMG_TRANSFER_IEC_61966_2_1, TransferCharacteristics::SRGB }, { ZIMG_TRANSFER_2020_10, TransferCharacteristics::REC_709 }, diff --git a/src/zimg/api/zimg.h b/src/zimg/api/zimg.h index 96c2587d..3c15ceb2 100644 --- a/src/zimg/api/zimg.h +++ b/src/zimg/api/zimg.h @@ -280,6 +280,7 @@ typedef enum zimg_transfer_characteristics_e { ZIMG_TRANSFER_INTERNAL = -1, /**< Not part of the API. */ ZIMG_TRANSFER_709 = 1, ZIMG_TRANSFER_UNSPECIFIED = 2, + ZIMG_TRANSFER_470BG = 5, ZIMG_TRANSFER_601 = 6, /* Equivalent to 1. */ ZIMG_TRANSFER_240M = 7, ZIMG_TRANSFER_LINEAR = 8, diff --git a/src/zimg/colorspace/colorspace.h b/src/zimg/colorspace/colorspace.h index c17a2b5e..424e90c1 100644 --- a/src/zimg/colorspace/colorspace.h +++ b/src/zimg/colorspace/colorspace.h @@ -38,6 +38,7 @@ enum class TransferCharacteristics { LOG_10, LOG_SQRT, REC_709, + REC_470_BG, SMPTE_240M, XVYCC, SRGB, diff --git a/src/zimg/colorspace/gamma.cpp b/src/zimg/colorspace/gamma.cpp index 6b2749c4..cafdb06d 100644 --- a/src/zimg/colorspace/gamma.cpp +++ b/src/zimg/colorspace/gamma.cpp @@ -120,6 +120,16 @@ float rec_1886_inverse_eotf(float x) noexcept return x < 0.0f ? 0.0f : zimg_x_powf(x, 1.0f / 2.4f); } +float rec_470bg_eotf(float x) noexcept +{ + return x < 0.0f ? 0.0f : zimg_x_powf(x, 2.8f); +} + +float rec_470bg_inverse_eotf(float x) noexcept +{ + return x < 0.0f ? 0.0f : zimg_x_powf(x, 1.0f / 2.8f); +} + float smpte_240m_eotf(float x) noexcept { if (x < SMPTE_240M_BETA) @@ -302,6 +312,10 @@ TransferFunction select_transfer_function(TransferCharacteristics transfer, doub func.to_linear = scene_referred ? rec_709_inverse_oetf : rec_1886_eotf; func.to_gamma = scene_referred ? rec_709_oetf : rec_1886_inverse_eotf; break; + case TransferCharacteristics::REC_470_BG: + func.to_linear = rec_470bg_eotf; + func.to_gamma = rec_470bg_inverse_eotf; + break; case TransferCharacteristics::SMPTE_240M: func.to_linear = smpte_240m_eotf; func.to_gamma = smpte_240m_inverse_eotf;