7#ifndef QSSGCPUTONEMAPPER_P_H
8#define QSSGCPUTONEMAPPER_P_H
21#include <QtGui/qvector3d.h>
29 return QVector3D(std::sqrt(a.x()), std::sqrt(a.y()), std::sqrt(a.z()));
34 return QVector3D(std::max(a.x(), b.x()), std::max(a.y(), b.y()), std::max(a.z(), b.z()));
39 return QVector3D(qBound(b, a.x(), c), qBound(b, a.y(), c), qBound(b, a.z(), c));
44 return QVector3D(a.x() + b, a.y() + b, a.z() + b);
47template<
typename mType>
50 return vadd(m * a, b);
57 const QVector3D S1 = vsqrt(c);
58 const QVector3D S2 = vsqrt(S1);
59 const QVector3D S3 = vsqrt(S2);
60 return 0.58512238f * S1 + 0.78314035f * S2 - 0.36826273f * S3;
65 const QVector3D cc = vmax(QVector3D(0.0f, 0.0f, 0.0f), vadd(c, -0.004f));
66 return (cc * mad(6.2f, cc, 0.5f)) / vadd(cc * mad(6.2f, cc, 1.7f), 0.06f);
71 const float A = 2.51f;
72 const float B = 0.03f;
73 const float C = 2.43f;
74 const float D = 0.59f;
75 const float E = 0.14f;
76 return tonemapLinearToSrgb(vclamp((c * mad(A, c, B)) / vadd(c * mad(C, c, D), E), 0.0f, 1.0f));
81 const float A = 0.15f;
82 const float B = 0.50f;
83 const float C = 0.10f;
84 const float D = 0.20f;
85 const float E = 0.02f;
86 const float F = 0.30f;
87 return vadd(vadd(c * mad(A, c, C * B), D * E) / vadd(c * mad(A, c, B), D * F), -E / F);
92 static const QVector3D whiteScale = QVector3D(1.0f, 1.0f, 1.0f) / tonemapFilmicSub(QVector3D(11.2f, 11.2f, 11.2f));
93 return tonemapLinearToSrgb(tonemapFilmicSub(c * 2.0f) * whiteScale);
QVector3D vclamp(const QVector3D &a, float b, float c)
QVector3D vadd(const QVector3D &a, float b)
QVector3D tonemapFilmicSub(const QVector3D &c)
QVector3D vmax(const QVector3D &a, const QVector3D &b)
QVector3D mad(mType m, const QVector3D &a, float b)
QVector3D tonemapFilmic(const QVector3D &c)
QVector3D tonemapHejlDawson(const QVector3D &c)
QVector3D tonemapAces(const QVector3D &c)
QVector3D tonemapLinearToSrgb(const QVector3D &c)
QVector3D vsqrt(const QVector3D &a)