C++ sRGB<-&燃气轮机;线性RGB转换精度
我试图理解图像/视频处理的基础知识,最近我了解到所有的处理都应该应用于图像的线性表示。因此,我为sRGB->RGB和RGB->sRGB编写了两个函数:C++ sRGB<-&燃气轮机;线性RGB转换精度,c++,image,colors,C++,Image,Colors,我试图理解图像/视频处理的基础知识,最近我了解到所有的处理都应该应用于图像的线性表示。因此,我为sRGB->RGB和RGB->sRGB编写了两个函数: void sRGB2lRGB(std::vector<unsigned char>& in, std::vector<unsigned char>& out) { std::vector<double> temp(in.begin(), in.end()); for (int
void sRGB2lRGB(std::vector<unsigned char>& in, std::vector<unsigned char>& out)
{
std::vector<double> temp(in.begin(), in.end());
for (int i = 0; i < temp.size(); i++)
{
temp[i] /= 255.0;
}
for (int i = 0; i < temp.size(); i++)
{
if (temp[i] <= 0.04045)
{
temp[i] /= 12.92;
}
else
{
temp[i] = std::pow((temp[i] + 0.055) / 1.055, 2.4);
}
}
for (int i = 0; i < temp.size(); i++)
{
out[i] = temp[i] * (int)255 + 0.5;
}
}
void lRGB2sRGB(std::vector<unsigned char>& in, std::vector<unsigned char>& out)
{
std::vector<double> temp(in.begin(), in.end());
for (int i = 0; i < temp.size(); i++)
{
temp[i] /= 255.0;
}
for (int i = 0; i < temp.size(); i++)
{
if (temp[i] <= 0.0031308)
{
temp[i] *= 12.92;
}
else
{
temp[i] = 1.055 * std::pow(temp[i], 1.0 / 2.4) - 0.055;
}
}
for (int i = 0; i < temp.size(); i++)
{
out[i] = temp[i] * (int)255 + 0.5;
}
}
我错在哪里?因为您通过将线性浮点值转换为整数表示来量化它们,所以转换确实是破坏性的 然而,出现这种情况并不奇怪:这实际上是使用sRGB逆电光传递函数(EOTF)编码数据时的意图。其目的是通过8位信号传输数据,同时保持良好的感知一致性,总体带宽降低 我会参考查尔斯·波因顿和波因顿,C.&芬特,B.(2014)。数字图像表示和显示的感知一致性。色彩研究与应用,39(1),6-15
请注意,此处的“对话”应为“转换”。在
sRGB2lRGB
中,对于小于7的所有输入值,您对out[i]
的计算将为0,因此在尝试反向计算时,您将获得相同的值。看起来这是线性空间的一个功能,但是,由于black附近的信息基本上丢失了,我看不出该对话是如何恢复的:/
int main()
{
std::vector<unsigned char> in(255);
std::vector<unsigned char> out(255);
std::vector<unsigned char> out2(255);
for (int i = 0; i < 255; i++)
{
in[i] = i;
}
sRGB2lRGB(in, out);
lRGB2sRGB(out, out2);
for (int i = 0; i < 255; i++)
{
if (out2[i] != i)
{
std::cout << "was: " << (int)in[i] << ", now: " << (int)out2[i] << '\n';
}
}
}
was: 1, now: 0
was: 2, now: 0
was: 3, now: 0
was: 4, now: 0
was: 5, now: 0
was: 6, now: 0
was: 7, now: 13
was: 8, now: 13
was: 9, now: 13
was: 10, now: 13
was: 11, now: 13
was: 12, now: 13
was: 14, now: 13
was: 15, now: 13
was: 16, now: 13
was: 17, now: 13
was: 18, now: 22
was: 19, now: 22
was: 20, now: 22
was: 21, now: 22
was: 23, now: 22
was: 24, now: 22
was: 25, now: 22
was: 26, now: 28
was: 27, now: 28
was: 29, now: 28
was: 30, now: 28
was: 31, now: 28
was: 32, now: 34
was: 33, now: 34
was: 35, now: 34
was: 36, now: 34
was: 37, now: 38
was: 39, now: 38
was: 40, now: 38
was: 41, now: 42
was: 43, now: 42
was: 44, now: 42
was: 45, now: 46
was: 47, now: 46
was: 48, now: 50
was: 49, now: 50
was: 51, now: 50
was: 52, now: 53
was: 54, now: 53
was: 55, now: 56
was: 57, now: 56
was: 58, now: 59
was: 60, now: 61
was: 62, now: 61
was: 63, now: 64
was: 65, now: 64
was: 67, now: 66
was: 68, now: 69
was: 70, now: 71
was: 72, now: 73
was: 74, now: 73
was: 76, now: 75
was: 78, now: 77
was: 80, now: 79
was: 82, now: 83
was: 84, now: 85
was: 87, now: 86
was: 89, now: 88
was: 91, now: 92
was: 94, now: 95
was: 97, now: 96
was: 100, now: 99
was: 103, now: 104
was: 107, now: 106
was: 111, now: 112
was: 116, now: 117
was: 123, now: 124