我是靠谱客的博主 称心白猫,最近开发中收集的这篇文章主要介绍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实现的全部内容,希望文章能够帮你解决YUV444转RGB24的verilog实现所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部