【MATLAB】读取视频,提取视频每一帧特征值并存成EXCEL,并保存个别图像

1、读取视频

2、对视频尺寸进行预处理到4K

3、分析每帧特征

4、将每帧特征存储到Excel表格

5、将特殊画面存进对应文件夹里

matlab 复制代码
clear ;close all;clc;

%初始化
fileName = 'grayscale.mp4'; %视频名称
filepath=strcat('./input/',fileName);
obj = VideoReader(filepath);
numFrames = obj.NumFrames;% 帧的总数
h=obj.Width;
v=obj.Height;

vh_th=0.7;%16:9差异设置,abs(h/v-16/9)<vh_th不加黑框

frame_UD=zeros(2160,3840,3,'uint8');
YCbCr=zeros(2160,3840,'double');
frame_Falg=zeros(numFrames,4,'double');
APL=zeros(1,1,'double');

savepath=strcat('./output/',fileName(1:end-4));
if ~exist(savepath, 'dir')
   savepath_status = mkdir(savepath);%如果路径不存在则新建一个
end


for k = 1 : numFrames% 读取数据
 
    frame = read(obj,k);
    %视频大小预处理
    if abs(h/v-16/9)<vh_th
        frame_UD=imresize(frame,[2160,3840],'bilinear');%16:9插值到4K
        black_add=0;
    else
        if h>v
            frame_new_h=imresize(frame,[v,3840],'bilinear');
            start=fix((2160-v)/2);
            frame_UD(start:start+v-1,:,:)=frame_new_h;
            black_add=(2160-v)*3840;

        else
            frame_new_v=imresize(frame,[2160,h],'bilinear');
            start=fix((3840-h)/2);
            frame_UD(:,start:start+h-1,:)=frame_new_v;
            black_add=(3840-h)*2160;
        end
    end

    %APL generate
    YCbCr=0.299*frame_UD(:,:,1)+0.587*frame_UD(:,:,2)+0.114*frame_UD(:,:,3);
    APL=mean2(YCbCr)/255;

    %0~4pixel count
    if APL>=0 && APL <0.2
        Gray_range=4;
    elseif APL>=0.2 && APL <0.4
        Gray_range=5;
    elseif APL>=0.4 && APL <0.6
        Gray_range=6;
    elseif APL>=0.6 && APL <0.8
        Gray_range=8;
    elseif APL>=0.8 && APL <=1
        Gray_range=10;
    else
        ray_range=10;
    end
    
    Gray_cnt=fix(sum(sum(sum(frame_UD < Gray_range)))/3);
   if  Gray_cnt>(8295+black_add)
       grayscale_gradient_Flag=1;
   else
       grayscale_gradient_Flag=0;
   end


 frame_Falg(k,1)=k;
 frame_Falg(k,2)=APL;
 frame_Falg(k,3)=Gray_cnt;
 frame_Falg(k,4)=grayscale_gradient_Flag;

 % imshow(frame_UD);%显示帧

 if grayscale_gradient_Flag==1
 WritePath=strcat('./output/',fileName(1:end-4),'/',num2str(k),'.bmp');  
 imwrite(frame_UD,WritePath);% 保存帧
 end

end


Writepath_excel=strcat('./output/',fileName(1:end-4),'_analysis.xlsx');
%方式1,速度慢
%Writdetail_excel = {'Frame num', 'APL', 'Gray count','grayscale_like' };
% for k=1:numFrames
% Writdetail_excel (k+1,:)={frame_Falg(k,1),frame_Falg(k,2),frame_Falg(k,3),frame_Falg(k,4)};
% end

%方式2,矩阵操作加速
 Writdetail_excel (1,:)={'Frame num', 'APL', 'Gray count','grayscale_like' };
 Writdetail_excel (2:numFrames+1,:)=num2cell(frame_Falg(:,:));


writecell(Writdetail_excel,Writepath_excel);
disp('Analysis Done!');
相关推荐
kaikaile19959 小时前
风、浪、流环境模型的船舶三自由度(纵荡、横荡、艏摇)运动仿真MATLAB
开发语言·人工智能·matlab
时空自由民.12 小时前
音视频图片压缩
音视频
日取其半万世不竭12 小时前
PeerTube 部署指南:自建视频托管平台
云原生·eureka·音视频
luoqice13 小时前
FLV文件解析
音视频
byte轻骑兵14 小时前
【AVRCP】规范精讲[10]:链路管理器LM互操作规则与场景落地
人工智能·音视频·蓝牙·avrcp·音视频控制
JK Chen15 小时前
faster_whisper,视频转文字,并生成字幕文件
python·whisper·音视频
foundbug9991 天前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
矢志航天的阿洪1 天前
用 MATLAB 控制 STK Aviator:从零搭建一个 AWACS 支援作战场景
开发语言·matlab
freexyn1 天前
Matlab自学笔记七十六:表达式的展开、因式分解、化简、合并同类项
笔记·算法·matlab
wearegogog1231 天前
基于Q-learning的栅格地图路径规划MATLAB仿真程序
开发语言·算法·matlab