YUV444转RGB24的verilog实现

    最近做华为Atlas200二次开发项目中,需要把YUV的数据,转换成RGB24。网上公式很多,笔者利用的公式如下:

 

    R = 1.164(Y-16) + 1.596(Cr-128)
    G = 1.164(Y-16) - 0.391(Cb-128) - 0.813(Cr-128)
    B = 1.164(Y-16) + 2.018(Cb-128)
   将上述公式进行转换:

 

    R = 1.164Y + 1.596Cr - 222.912
    G = 1.164Y - 0.391Cb - 0.813Cr + 135.488
    B = 1.164Y + 2.018Cb - 276.928
    向左移位,寄放大2的9次方,512倍后如下:


    R << 9 = 596Y                +     817Cr    -    114131
    G << 9 = 596Y    -    200Cb    -    416Cr    +    69370
    B << 9 = 596Y    +    1033Cb                -    141787

根据以上公式进行转换,转换完之后再右移9位恢复就行。

需要说明的是,最后数据处理的时候,如果是负数,按0处理,如果大于255,按255处理。

可能有人要问,负数怎么判断?负数的话,判断它的补码的符号位是否为1即可,为1就是负数。

你可能感兴趣的:(YUV444转RGB24的verilog实现)