Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qcolortransfergeneric_p.h
Go to the documentation of this file.
1// Copyright (C) 2024 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QCOLORTRANSFERGENERIC_P_H
5#define QCOLORTRANSFERGENERIC_P_H
6
7//
8// W A R N I N G
9// -------------
10//
11// This file is not part of the Qt API. It exists purely as an
12// implementation detail. This header file may change from version to
13// version without notice, or even be removed.
14//
15// We mean it.
16//
17
18#include <QtGui/private/qtguiglobal_p.h>
19
20#include <cmath>
21
23
24// Defines the a generic transfer function for our HDR functions
26{
27public:
28 using ConverterPtr = float (*)(float);
29 constexpr QColorTransferGenericFunction(ConverterPtr toLinear = nullptr, ConverterPtr fromLinear = nullptr) noexcept
30 : m_toLinear(toLinear), m_fromLinear(fromLinear)
31 {}
32
34 {
35 return QColorTransferGenericFunction(hlgToLinear, hlgFromLinear);
36 }
38 {
39 return QColorTransferGenericFunction(pqToLinear, pqFromLinear);
40 }
41
42 float apply(float x) const
43 {
44 return m_toLinear(x);
45 }
46
47 float applyInverse(float x) const
48 {
49 return m_fromLinear(x);
50 }
51
52 bool operator==(const QColorTransferGenericFunction &o) const noexcept
53 {
54 return m_toLinear == o.m_toLinear && m_fromLinear == o.m_fromLinear;
55 }
56 bool operator!=(const QColorTransferGenericFunction &o) const noexcept
57 {
58 return m_toLinear != o.m_toLinear || m_fromLinear != o.m_fromLinear;
59 }
60
61private:
62 ConverterPtr m_toLinear = nullptr;
63 ConverterPtr m_fromLinear = nullptr;
64
65 // HLG from linear [0-12] -> [0-1]
66 static float hlgFromLinear(float x)
67 {
68 x = std::clamp(x, 0.f, 12.f);
69 if (x > 1.f)
70 return m_hlg_a * std::log(x - m_hlg_b) + m_hlg_c;
71 return std::sqrt(x * 0.25f);
72 }
73
74 // HLG to linear [0-1] -> [0-12]
75 static float hlgToLinear(float x)
76 {
77 x = std::clamp(x, 0.f, 1.f);
78 if (x < 0.5f)
79 return (x * x) * 4.f;
80 return std::exp((x - m_hlg_c) / m_hlg_a) + m_hlg_b;
81 }
82
83 constexpr static float m_hlg_a = 0.17883277f;
84 constexpr static float m_hlg_b = 1.f - (4.f * m_hlg_a);
85 constexpr static float m_hlg_c = 0.55991073f; // 0.5 - a * ln(4 * a)
86
87 // BT.2100-2 Reference PQ EOTF and inverse (see Table 4)
88 // PQ to linear [0-1] -> [0-64]
89 static float pqToLinear(float e)
90 {
91 e = std::clamp(e, 0.f, 1.f);
92 // m2-th root of E'
93 const float eRoot = std::pow(e, 1.f / m_pq_m2);
94 // rational transform
95 const float yBase = (std::max)(eRoot - m_pq_c1, 0.0f) / (m_pq_c2 - m_pq_c3 * eRoot);
96 // calculate Y = yBase^(1/m1)
97 const float y = std::pow(yBase, 1.f / m_pq_m1);
98 // scale Y to Fd
99 return y * m_pq_f;
100 }
101
102 // PQ from linear [0-64] -> [0-1]
103 static float pqFromLinear(float fd)
104 {
105 fd = std::clamp(fd, 0.f, 64.f);
106 // scale Fd to Y
107 const float y = fd * (1.f / m_pq_f);
108 // yRoot = Y^m1 -- "root" because m1 is <1
109 const float yRoot = std::pow(y, m_pq_m1);
110 // rational transform
111 const float eBase = (m_pq_c1 + m_pq_c2 * yRoot) / (1.f + m_pq_c3 * yRoot);
112 // calculate E' = eBase^m2
113 return std::pow(eBase, m_pq_m2);
114 }
115
116 constexpr static float m_pq_c1 = 107.f / 128.f; // c3 - c2 + 1
117 constexpr static float m_pq_c2 = 2413.f / 128.f;
118 constexpr static float m_pq_c3 = 2392.f / 128.f;
119 constexpr static float m_pq_m1 = 1305.f / 8192.f;
120 constexpr static float m_pq_m2 = 2523.f / 32.f;
121 constexpr static float m_pq_f = 64.f; // This might need to be set based on scene metadata
122};
123
124QT_END_NAMESPACE
125
126#endif // QCOLORTRANSFERGENERIC_P_H
QColorVector apply(const QColorVector &v) const
QList< QColorVector > table
uint32_t gridPointsY
uint32_t gridPointsW
bool isEmpty() const
uint32_t gridPointsX
uint32_t gridPointsZ
QColorMatrix inverted() const
static QColorMatrix toXyzFromSRgb()
static QColorMatrix toXyzFromAdobeRgb()
bool isValid() const
friend bool comparesEqual(const QColorMatrix &lhs, const QColorMatrix &rhs) noexcept
QColorVector g
constexpr float determinant() const
static QColorMatrix identity()
QColorMatrix transposed() const
static QColorMatrix fromScale(QColorVector v)
friend constexpr QColorMatrix operator*(const QColorMatrix &a, const QColorMatrix &o)
QColorVector b
QColorVector r
bool isIdentity() const noexcept
static QColorMatrix toXyzFromDciP3D65()
static QColorMatrix chromaticAdaptation(const QColorVector &whitePoint)
static QColorMatrix toXyzFromProPhotoRgb()
QColorVector map(const QColorVector &c) const
static QColorMatrix toXyzFromBt2020()
constexpr bool isNull() const
void setTransferFunctionTables(const QList< uint16_t > &redTransferFunctionTable, const QList< uint16_t > &greenTransferFunctionTable, const QList< uint16_t > &blueTransferFunctionTable)
QColorSpacePrivate(QPointF whitePoint, const QList< uint16_t > &transferFunctionTable)
QColorVector whitePoint
QColorSpacePrivate(QPointF whitePoint, QColorSpace::TransferFunction transferFunction, float gamma)
QColorSpacePrivate(const QColorSpace::PrimaryPoints &primaries, const QList< uint16_t > &transferFunctionTable)
QColorTransform transformationToColorSpace(const QColorSpacePrivate *out) const
QList< Element > mAB
QList< Element > mBA
void clearElementListProcessingForEdit()
QColorMatrix chad
void setTransferFunctionTable(const QList< uint16_t > &transferFunctionTable)
QColorTransform transformationToXYZ() const
bool isThreeComponentMatrix() const
QColorSpacePrivate(const QColorSpace::PrimaryPoints &primaries, const QList< uint16_t > &redTransferFunctionTable, const QList< uint16_t > &greenTransferFunctionTable, const QList< uint16_t > &blueRransferFunctionTable)
QColorSpacePrivate(const QColorSpacePrivate &other)=default
static const QColorSpacePrivate * get(const QColorSpace &colorSpace)
QColorSpacePrivate(const QColorSpace::PrimaryPoints &primaries, QColorSpace::TransferFunction transferFunction, float gamma)
static QColorSpacePrivate * get(QColorSpace &colorSpace)
bool isValid() const noexcept
QColorMatrix toXyz
QColorSpacePrivate(QColorSpace::NamedColorSpace namedColorSpace)
bool equals(const QColorSpacePrivate *other) const
Q_DECLARE_FLAGS(Hints, Hint)
QColorTransferFunction inverted() const
friend bool operator!=(const QColorTransferFunction &f1, const QColorTransferFunction &f2)
QColorTransferFunction(float a, float b, float c, float d, float e, float f, float g) noexcept
static QColorTransferFunction fromGamma(float gamma)
bool matches(const QColorTransferFunction &o) const
static QColorTransferFunction fromBt2020()
friend bool operator==(const QColorTransferFunction &f1, const QColorTransferFunction &f2)
static QColorTransferFunction fromProPhotoRgb()
static QColorTransferFunction fromSRgb()
static QColorTransferGenericFunction pq()
static QColorTransferGenericFunction hlg()
bool operator==(const QColorTransferGenericFunction &o) const noexcept
bool operator!=(const QColorTransferGenericFunction &o) const noexcept
constexpr QColorTransferGenericFunction(ConverterPtr toLinear=nullptr, ConverterPtr fromLinear=nullptr) noexcept
The QColorTransform class is a transformation between color spaces.
bool comparesEqual(const QColorVector &v1, const QColorVector &v2) noexcept
static void cleanupPredefinedColorspaces()
static bool compareElement(const QColorSpacePrivate::TransferElement &element, const QColorSpacePrivate::TransferElement &other)
QDebug operator<<(QDebug dbg, const QColorCLUT &)
QDebug operator<<(QDebug dbg, const QColorSpace &colorSpace)
QDebug operator<<(QDebug dbg, const QColorMatrix &)
static bool compareElement(const QColorMatrix &element, const QColorMatrix &other)
QDataStream & operator>>(QDataStream &s, QColorSpace &colorSpace)
QDataStream & operator<<(QDataStream &s, const QColorSpace &image)
QDebug operator<<(QDebug dbg, const QColorVector &)
QColorMatrix qColorSpacePrimaryPointsToXyzMatrix(const QColorSpace::PrimaryPoints &primaries)
static bool compareElements(const T &element, const QColorSpacePrivate::Element &other)
static bool compareElement(const QColorCLUT &element, const QColorCLUT &other)
static bool compareElement(const QColorVector &element, const QColorVector &other)
QDebug operator<<(QDebug dbg, const QColorSpacePrivate::TransferElement &)
QT_BEGIN_NAMESPACE bool qColorSpacePrimaryPointsAreValid(const QColorSpace::PrimaryPoints &primaries)
Q_DECLARE_OPERATORS_FOR_FLAGS(QColorTransferFunction::Hints)
QDebug operator<<(QDebug dbg, const QFileInfo &fi)
bool comparesEqual(const QFileInfo &lhs, const QFileInfo &rhs)
LUT(const LUT &other)
const std::shared_ptr< QColorTrcLut > & operator[](int i) const
std::shared_ptr< QColorTrcLut > & operator[](int i)
std::shared_ptr< QColorTrcLut > table[3]