Python 实现RGB和YUV互转

RGB和YUV互转

python 复制代码
class Color:
    # BT601 数字Full range
    def __init__(self):
        pass

    def YUV2RGB(self, Y, U, V):
        # R,G,B (0~255)
        R= Y + ((360 * (V - 128))>>8)
        G= Y - (( ( 88 * (U - 128)  + 184 * (V - 128)) )>>8) 
        B= Y +((455 * (U - 128))>>8) 
        return R,G,B
    
    def RGB2YUV(self, R, G, B):
        # Y(0~255),  U,V(-128~128)          
        Y = (77*R + 150*G + 29*B)>>8
        U = ((-44*R  - 87*G  + 131*B)>>8) + 128
        V = ((131*R - 110*G - 21*B)>>8) + 128
        return Y,U,V
    
    def YUV2RGBF(self, Y, U, V):
        # R,G,B (0.0~255.0)
        R = Y+1.4075*(V-128)
        G = Y-0.3455*(U-128)-0.7169*(V-128)
        B = Y+1.779*(U-128)
        return R,G,B
    
    def RGB2YUVF(self, R, G, B):
        # Y(0.0~255.0),  U,V(-128.0~128.0)
        Y = 0.299*R + 0.587*G + 0.114*B
        U = -0.169*R - 0.331*G + 0.5*B + 128
        V = 0.5*R - 0.419*G - 0.081*B + 128
        return Y,U,V


# 测试代码:    
color = Color()

y,u,v = color.RGB2YUV(255, 255, 255)
print("Y:{:.02f}, U:{:.02f}, V:{:.02f}".format(y, u, v))

r,g,b = color.YUV2RGB(y,u,v)
print("R:{:.02f}, G:{:.02f}, B:{:.02f}".format(r, g, b))
相关推荐
q***441514 小时前
Java性能优化实战技术文章大纲Java性能优化的核心目标与原则
java·开发语言·性能优化
csbysj202014 小时前
Ruby CGI Session
开发语言
OliverZhao14 小时前
iPhoto:基于 Python + PySide6 的高性能 macOS 风格照片管理器
python
SoRound14 小时前
【Shopee Games AI 模型使用经验】年度总结之 ------ 识别人脸特征,生成动漫形象
python·openai
郝学胜-神的一滴14 小时前
机器学习特征预处理:缺失值处理全攻略
人工智能·python·程序人生·机器学习·性能优化·sklearn
lly20240614 小时前
NumPy 迭代数组
开发语言
rgeshfgreh14 小时前
Python闭包:函数记住状态的秘密
开发语言·python
古城小栈14 小时前
Cargo命令工具
开发语言·rust
0***m82214 小时前
MATLAB高效算法实战技术文章大纲向量化运算替代循环结构
开发语言·算法·matlab
flysh0514 小时前
委托实战案例
开发语言·c#