Проблемы преобразования RGB в YCbCr
Мне нужно преобразовать изображение RGB в цветовое пространство YCbCr, но у меня есть некоторые проблемы со смещением цвета, я использовал все формулы и получил тот же результат.
Формула в питоне
cbcr[0] = int(0.299*rgb[0] + 0.587*rgb[1] + 0.114*rgb[2]) #Y
cbcr[1] = int(-0.1687*rgb[0] - 0.3313*rgb[1] + 0.5*rgb[2] + 128) #Cb
cbcr[2] = int( 0.5*rgb[0] - 0.4187*rgb[1] - 0.0813*rgb[2] + 128) #Cr
Я знаю, что должен получить одно и то же изображение с другим способом записи данных, но я получил неправильный цветовой результат.
http://i.imgur.com/zHuv8yq.png Оригинал
http://i.imgur.com/Ek2WEA1.png Результат
Так как же получить нормальное изображение или конвертировать RGB PNG в YCbCr 4:2:2?
1 ответ
Это должно работать (приблизительно)
def _ycc(r, g, b): # in (0,255) range
y = .299*r + .587*g + .114*b
cb = 128 -.168736*r -.331364*g + .5*b
cr = 128 +.5*r - .418688*g - .081312*b
return y, cb, cr
def _rgb(y, cb, cr):
r = y + 1.402 * (cr-128)
g = y - .34414 * (cb-128) - .71414 * (cr-128)
b = y + 1.772 * (cb-128)
return r, g, b
>>> c = _ycc(10, 20, 30)
>>> _rgb(*c)
(10.000005760000002, 20.000681726399996, 29.996457920000005)