Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/kubernetes/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ sRGB<-&燃气轮机;线性RGB转换精度_C++_Image_Colors - Fatal编程技术网

C++ sRGB<-&燃气轮机;线性RGB转换精度

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

我试图理解图像/视频处理的基础知识,最近我了解到所有的处理都应该应用于图像的线性表示。因此,我为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 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