%% read_qcif_yuv_to_mat.m
% 读取 QCIF YUV420 (176x144x300) 为 3D 数组 X，并保存为 .mat

clc; clear;

yuv_file   = 'highway_qcif.yuv';   % 换成你的 yuv 文件名
mat_file   = 'highway.mat';        % 输出的 mat 文件名
width      = 176;
height     = 144;
numFrames  = 2000;

% 预分配：height x width x numFrames
X = zeros(height, width, numFrames, 'uint8');

fid = fopen(yuv_file, 'rb');
if fid < 0
    error('无法打开文件: %s', yuv_file);
end

for f = 1:numFrames
    % -------- 读 Y 分量 --------
    Y_plane = fread(fid, width * height, 'uint8=>uint8');
    if numel(Y_plane) < width * height
        fclose(fid);
        error('文件长度不够，无法读到第 %d 帧的 Y 分量', f);
    end
    
    Y_frame = reshape(Y_plane, [width, height])';   % 变成 height x width
    X(:, :, f) = Y_frame;
    
    % -------- 跳过 U、V 分量（4:2:0）--------
    skipUV = width * height / 2;  % U+V 一共 w*h/2 字节
    dummy  = fread(fid, skipUV, 'uint8');
    if numel(dummy) < skipUV
        fclose(fid);
        error('文件长度不够，无法读到第 %d 帧的 UV 分量', f);
    end
end

fclose(fid);

% 保存为 mat，变量名为 X
save(mat_file, 'X');

% 简单检查：显示第一帧
figure; imshow(X(:,:,1), []);
title('第 1 帧的 Y 分量');
