读取4:2:0格式YUV序列的Y分量、U分量以及V分量,并分别保存为.yuv格式(matlab实现)

 读取4:2:0格式YUV序列的Y分量、U分量以及V分量,并分别保存为.yuv格式,不多说,具体程序如下:

read_Y_U_V.m

%%  读取4:2:0格式YUV的Y、U和V分量,然后将三个分量分别保存为.yuv格式

clear
clc

%% Read yuv from file
row=144;      %   长度
col=176;      %   宽度
fnum=300;     %   帧数

yuvseq = 'foreman_qcif_300.yuv';        % 输入yuv序列名称
len=length(yuvseq);
yuvName=yuvseq(1:len-4);
fid = fopen(yuvseq, 'r');

rec_Y=zeros(col,row,fnum);
rec_U=zeros(col/2,row/2,fnum);
rec_V=zeros(col/2,row/2,fnum);

for f=1:fnum
    [rec_Y(:,:,f),count] = fread(fid,[col,row],'uchar');
    [rec_U(:,:,f),count1]=fread(fid,[col/2,row/2],'uchar');
    [rec_V(:,:,f),count2]=fread(fid,[col/2,row/2],'uchar');
end

filename_Y=sprintf('%s%s',yuvName,'_Y.yuv');         %% 生成.yuv名称
outfid_Y=fopen(filename_Y,'wb');

filename_U=sprintf('%s%s',yuvName,'_U.yuv');     
outfid_U=fopen(filename_U,'wb');

filename_V=sprintf('%s%s',yuvName,'_V.yuv');     
outfid_V=fopen(filename_V,'wb');

for f=1:fnum
    pic_Y=uint8(rec_Y(:,:,f)');                      %% '代表转置操作
    fwrite(outfid_Y,rec_Y(:,:,f), 'uint8');   
    imshow(pic_Y);                                   %%  将每个矩阵显示为图片
end

for f=1:fnum   
    pic_U=uint8(rec_U(:,:,f)');
    fwrite(outfid_U,rec_U(:,:,f), 'uint8');
    imshow(pic_U);
end

for f=1:fnum   
    pic_V=uint8(rec_V(:,:,f)');
    fwrite(outfid_V,rec_V(:,:,f),  'uint8');
    imshow(pic_V);
end

fclose(fid);
fclose(outfid_Y);
fclose(outfid_U);
fclose(outfid_V);


  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rs勿忘初心

您的鼓励将是我的最大创动原动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值