24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1070  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料考研调剂 +24 云木达达 2026-04-11 26/1300 2026-04-12 00:23 by 蓝云思雨
[考研] 22408调剂求助 +7 毂12 2026-04-09 9/450 2026-04-11 09:23 by 哦哦123
[考研] 263能源动力专硕求调剂 +4 加大号饭盒袋 2026-04-10 4/200 2026-04-10 20:52 by gong120082
[考研] 一志愿京区985,085401电子信息,本科电子信息 +3 阳光开朗的男孩 2026-04-10 3/150 2026-04-10 16:29 by sophia_93
[考研] 285求调剂 +9 AZMK 2026-04-07 11/550 2026-04-10 15:24 by AZMK
[考研] 292求调剂 +9 笑笑袁 2026-04-09 9/450 2026-04-10 10:05 by LHGeng
[考研] 考研二轮调剂 +8 故人?? 2026-04-09 8/400 2026-04-10 09:44 by 青梅duoduo
[考研] 材料调剂 +11 一样YWY 2026-04-05 11/550 2026-04-10 09:32 by 钟洲2011
[考研] 08工学 309分求调剂 +6 Yin DY 2026-04-08 6/300 2026-04-10 09:18 by Delta2012
[考研] 278求调剂 +27 范婷娜 2026-04-07 31/1550 2026-04-09 20:49 by zhouxiaoyu
[考研] 一志愿华工085600 331分 +6 天下ww 2026-04-09 6/300 2026-04-09 18:59 by l_paradox
[考研] 求调剂希望还是希望在山河四省附近 +3 快乐的小白鸽 2026-04-05 3/150 2026-04-09 17:36 by wp06
[论文投稿] 求助文献原文 10+3 18500821399 2026-04-08 3/150 2026-04-09 16:56 by 北京莱茵润色
[考研] 化学工程与技术专业一志愿哈工程 291分B区 国家级大创负责人 有一作论文 +13 Emmy~ 2026-04-09 13/650 2026-04-09 14:47 by only周
[考研] 材料专硕322 +14 哈哈哈吼吼吼哈 2026-04-05 14/700 2026-04-09 13:25 by 5268321
[考研] 一志愿鲁东大学071000生物学学硕初试分数276求调剂 +3 慕绝cc 2026-04-09 3/150 2026-04-09 09:57 by liuhuiying09
[考研] 一志愿吉大化学327求调剂 +12 王王白石 2026-04-06 13/650 2026-04-08 16:05 by luoyongfeng
[考研] 生物学363调剂求助 +7 fanzhang6666 2026-04-06 9/450 2026-04-07 17:37 by lijunpoly
[考研] 081200-11408-276学硕求调剂 +5 崔wj 2026-04-05 5/250 2026-04-06 15:40 by lin-da
[考研] 332求调剂 +17 小小孟... 2026-04-05 18/900 2026-04-06 09:51 by 蓝云思雨
信息提示
请填处理意见