5#ifndef QSSGCPUTONEMAPPER_P_H
6#define QSSGCPUTONEMAPPER_P_H
19#include <QtGui/qvector3d.h>
27 return QVector3D(std::sqrt(a.x()), std::sqrt(a.y()), std::sqrt(a.z()));
32 return QVector3D(std::max(a.x(), b.x()), std::max(a.y(), b.y()), std::max(a.z(), b.z()));
37 return QVector3D(qBound(b, a.x(), c), qBound(b, a.y(), c), qBound(b, a.z(), c));
42 return QVector3D(a.x() + b, a.y() + b, a.z() + b);
45template<
typename mType>
48 return vadd(m * a, b);
55 const QVector3D S1 = vsqrt(c);
56 const QVector3D S2 = vsqrt(S1);
57 const QVector3D S3 = vsqrt(S2);
58 return 0.58512238f * S1 + 0.78314035f * S2 - 0.36826273f * S3;
63 const QVector3D cc = vmax(QVector3D(0.0f, 0.0f, 0.0f), vadd(c, -0.004f));
64 return (cc * mad(6.2f, cc, 0.5f)) / vadd(cc * mad(6.2f, cc, 1.7f), 0.06f);
69 const float A = 2.51f;
70 const float B = 0.03f;
71 const float C = 2.43f;
72 const float D = 0.59f;
73 const float E = 0.14f;
74 return tonemapLinearToSrgb(vclamp((c * mad(A, c, B)) / vadd(c * mad(C, c, D), E), 0.0f, 1.0f));
79 const float A = 0.15f;
80 const float B = 0.50f;
81 const float C = 0.10f;
82 const float D = 0.20f;
83 const float E = 0.02f;
84 const float F = 0.30f;
85 return vadd(vadd(c * mad(A, c, C * B), D * E) / vadd(c * mad(A, c, B), D * F), -E / F);
90 static const QVector3D whiteScale = QVector3D(1.0f, 1.0f, 1.0f) / tonemapFilmicSub(QVector3D(11.2f, 11.2f, 11.2f));
91 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)