24小时热门版块排行榜    

CyRhmU.jpeg
查看: 991  |  回复: 3

130098300

银虫 (正式写手)

[求助] 求一个RGB转到YUV颜色空间的源程序

如题,请大家看清楚啦,是RGB到YUV,不是YCbCr。要求是RGB到YUV420,如果有422,444的也一起发来吧。要求是:输入RGB图像,输出三幅图像,分别是Y,U,V。对于Y是和源图像一样大小,对于U和V则是一般大小啦,这个就不多说了。
小弟做了一个源程序,但不知道是否正确,所以想再找一个比较下。如果有的人请发一份到我的邮箱吧1400983@163.com,不胜感激了!
VC或者Matlab程序都可以!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

Working for the Lord with all my heart
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liliyawj

木虫 (初入文坛)

【答案】应助回帖

function dst = rgb2yuv(src)

% ensure this runs with rgb images as well as rgb triples
if(length(size(src)) > 2)
   
    % rgb image ([r] [g] )
    r = double(src(:,:,1));
    g = double(src(:,:,2));
    b = double(src(:,:,3));
   
elseif(length(src) == 3)
   
    % rgb triplet ([r, g, b])
    r = double(src(1));
    g = double(src(2));
    b = double(src(3));
   
else
   
    % unknown input format
    error('rgb2yuv: unknown input format');
   
end
   
% convert...
y = floor(0.3*r + 0.5881*g + 0.1118*b);
u = floor(-0.15*r - 0.2941*g + 0.3882*b + 128);
v = floor(0.35*r - 0.2941*g - 0.0559*b + 128);

% ensure valid range for uint8 values
y(y > 255) = 255;
y(y < 0)   = 0;
u(u > 255) = 255;
u(u < 0)   = 0;
v(v > 255) = 255;
v(v < 0)   = 0;


% generate output
if(length(size(src)) > 2)
   
    % yuv image ([y] [v])
    dst(:,:,1) = uint8(y);
    dst(:,:,2) = uint8(u);
    dst(:,:,3) = uint8(v);
   
else
   
    % yuv triplet ([y, u, v])
    dst = uint8([y, u, v]);
   
end
2楼2011-12-06 00:47:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

130098300

银虫 (正式写手)

引用回帖:
2楼: Originally posted by liliyawj at 2011-12-06 00:47:39:
function dst = rgb2yuv(src)

% ensure this runs with rgb images as well as rgb triples
if(length(size(src)) > 2)
   
    % rgb image ([r] [g] )
    r = double(src(:,:,1));
    g = dou ...

你这个是YUV444的啊,我需要的是YUV420的,不好意思,不能给你分了,但还是谢谢你
Working for the Lord with all my heart
3楼2011-12-06 09:09:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

leywong

金虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
130098300(金币+8): 呵呵,这个我已经做出来了,但还是谢谢你 2011-12-11 10:19:57
% RGB=imread('00000002.jpg');                 %读入后便是一个RGB矩阵 width,height原始图象的宽度和高度
[width,height,z]=size(RGB);
Y=zeros(width,height,'uint8');              %建立1个width*height大小的空矩阵,把这个值赋给Y

yuv=rgb2ycbcr(RGB);                         %调用内部函数rgb2ycbcr,初步处理,转化RGB的值为YcbCr颜色空间,并把数据存储在yuv里面

Y(:,=yuv(:,:,1);                          %把yuv第1个矩阵值,赋给亮度Y空间
U=zeros(width/2,height/2,'uint8');          %建立1个(width/2)*(height/2)大小的空矩阵,把这个值赋给色度U
V=zeros(width/2,height/2,'uint8');          %建立1个(width/2)*(height/2)大小的空矩阵,把这个值赋给色度V
U(:,=yuv(1:2:width-1,1:2:height-1,2);     %从第一个字节开始隔2取1  由于每个像素均保留了U分量
V(:,=yuv(1:2:width-1,1:2:height-1,3);     %从第一个字节开始隔2取1  由于每个像素均保留了V分量

YY=zeros(width,height,'uint8');             %建立1个width*height大小的空矩阵,把这个值赋给YY
UU=zeros(width,height,'uint8');             %建立1个width*height大小的空矩阵,把这个值赋给UU
VV=zeros(width,height,'uint8');             %建立1个width*height大小的空矩阵,把这个值赋给VV
YY(:,=Y(:,:,1);                       %读取亮度Y某个特定的区域值给YY frame是选择那个区域,这里我们取frame==1
%同上
UU(1:2:width-1,1:2:height-1)=U(:,:,1);
UU(1:2:width-1,2:2:height)=U(:,:,1);
UU(2:2:width,1:2:height-1)=U(:,:,1);
UU(2:2:width,2:2:height)=U(:,:,1);
%并非每个像素均保留了U分量,故还要插值,这里直接用邻近的赋值了,最后恢复到width*height个
%同上
VV(1:2:width-1,1:2:height-1)=V(:,:,1);
VV(1:2:width-1,2:2:height)=V(:,:,1);
VV(2:2:width,1:2:height-1)=V(:,:,1);
VV(2:2:width,2:2:height)=V(:,:,1);

%YY,UU,VV转置并合并成三维数组   
YUV=cat(3,YY,UU,VV);
% RGB=ycbcr2rgb(YUV);                       %逆转换,YUV→RGB               
% imshow(RGB)                               %显示转换后的图片
%
% figure(2)
% imshow(yuv);
4楼2011-12-11 07:39:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 130098300 的主题更新
信息提示
请填处理意见