本程序来源于《MATLAB图像处理:能力提高与应用案例》这本书籍,这个书籍是适合初学matlab的新手加深对于matlab的学习与理解。

本段为主程序:

clear data
disp('input video');
% 读入视频图像wzw.avi并显示
avi = aviread('wzw.avi');
video = {avi.cdata};
for a = 1:length(video)
    imagesc(video{a});
    axis image off
    drawnow;
end;
disp('output video');
% 调用tracking()函数对运动目标进行跟踪
tracking(video);
以下为子程序:

function d = tracking(video)
% 功能:跟踪视频中的运动目标并显示
% 输入:video-待跟踪的视频
% 输出:d-差值图像序列

% 读入视频图像
if ischar(video)
    avi = aviread(video);
    pixels = double(cat(4,avi(1:2:end).cdata))/255;
    clear avi
else
    pixels = double(cat(4,video{1:2:end}))/255;
    clear video
end
% 将RGB图像转换成灰度图像
nFrames = size(pixels,4);
for f = 1:nFrames
   pixel(:,:,f) = (rgb2gray(pixels(:,:,:,f)));  
end
 [rows,cols]=size(pixel(:,:,1));
nrames=f;
% 将相邻两帧图像进行作差,并将差值图像转换为二值图像
for l = 2:nrames
d(:,:,l)=(abs(pixel(:,:,l)-pixel(:,:,l-1)));
k=d(:,:,l);
   bw(:,:,l) = im2bw(k, .2);
   bw1=bwlabel(bw(:,:,l));
   imshow(bw(:,:,l))
   hold on
% 标记运动物体的位置并显示
cou=1;
for h=1:rows
    for w=1:cols
     if(bw(h,w,l)>0.5)
      toplen = h;
           if (cou == 1)
            tpln=toplen;
         end
         cou=cou+1;
      break
     end
     end
end
disp(toplen);
coun=1;
for w=1:cols
    for h=1:rows
     if(bw(h,w,l)>0.5)
        
      leftsi = w;
     if (coun == 1)
            lftln=leftsi;
            coun=coun+1;
   end
      break
     end
    end
end
disp(leftsi);
disp(lftln);   
widh=leftsi-lftln;
heig=toplen-tpln;
widt=widh/2;
disp(widt);
heit=heig/2;
with=lftln+widt;
heth=tpln+heit;
wth(l)=with;
hth(l)=heth;
 
disp(heit);
disp(widh);
disp(heig);
rectangle('Position',[lftln tpln widh heig],'EdgeColor','r');
disp(with);
disp(heth);
plot(with,heth, 'r*');
drawnow;
hold off
end
本程序利用帧间差分法能够实现对单个目标的运动进行检测,并且用方框提示运动的目标。对于上述代码所提及视频,建议自己拍摄一个小视频,时间在5秒左右适宜,太大的话会引起内存溢出,视频的格式有严格的要求 ,须为 avi中的zjmedia uncompress rgb24,可以通过winavi来转换,如果视频出现报错disp(toplen),那就是视频不符合本程序的要求,程序代码经过本人多次的检验,能够正确的在matlab7.0中运行。

matlab之运动目标检测相关推荐

  1. 基于matlab的运动目标检测,基于matlab的运动目标检测.doc

    基于matlab的运动目标检测.doc 河北大学2011届本科生毕业论文(设计)11绪论1.1课题研究背景及意义运动目标检测是图像处理与计算机视觉的一个分支,在理论和实践上都有重大意义,长久以来一直被 ...

  2. MATLAB视频运动目标检测参考源码

    MATLAB视频运动目标检测参考源码 将视频截取成帧 fileName = 'q.avi'; %此处输入视频名称,要带后缀,注意好像只有wmv和avi格式 obj = VideoReader(file ...

  3. matlab对摄像头实时运动目标检测,基于Matlab实时运动目标跟踪检测系统

    2012.03 COMPUTER SECURITY 17 学术.技术 基于 Matlab 实时运动目标跟踪检测系统 汪惠兰,林航飞,李赔龙 (同济大学 交通运输与工程学院,上海 201804) 摘 要 ...

  4. MATLAB运动目标检测系统

    1 绪论 1.1 课题研究背景及意义 运动目标检测是图像处理与计算机视觉的一个分支,在理论和实践上都有重大意义,长久以来一直被国内外学者所关注.在实际中,视频监控利用摄像机对某一特定区域进行监视,是一 ...

  5. MATLAB运动目标检测

    1 绪论 课题研究背景及意义 运动目标检测是图像处理与计算机视觉的一个分支,在理论和实践上都有重大意义, 长久以来一直被国内外学者所关注.在实际中,视频监控利用摄像机对某一特定区域进行 监视,是一个细 ...

  6. Matlab实现---基于平均背景法的视频运动目标检测(有背景更新)

    目录 实现目标及说明 代码及说明 完整文件获取 实现目标及说明 MATLAB--编程实现基于平均背景法的视频运动目标检测,并且要不断更新背景. 网上找到的很多关于运动目标检测的,多数是用OpenCV或 ...

  7. matlab 运动检测,如何使用MATLAB进行运动目标的检测

    运动目标检测是图像处理与计算机视觉的一个分支,在理论和实践上都有重大意义,长久以来一直被国内外学者所关注.在实际中,视频监控利用摄像机对某一特定区域进行监视,是一个细致和连续的过程,它可以由人来完成, ...

  8. matlab帧间差分法前景提取_matlab采用帧差法实现运动目标检测

    帧间差分法是一种通过对视频图像序列中相邻两帧作差分运算来获得运动目标轮廓的方法,它可以很好地适用于存在多个运动目标和摄像机移动的情况.当监控场景中出现异常物体运动时,帧与帧之间会出现较为明显的差别,两 ...

  9. 基于opencV的动态背景下运动目标检测及跟踪(修改版)

    基于openCV的动态背景下的运动目标检测 from: http://www.mianfeiwendang.com/doc/89c6692a222a84b2ced0d502/1 摘要:介绍在动态背景下 ...

最新文章

  1. java实现将String的数字提取出来
  2. python中defaultdict()函数的介绍以及应用场景
  3. SURF算法与源码分析、上
  4. 文献记录(part48)--Vector of Locally and Adaptively Aggregated Descriptors for Image Feature ...
  5. 注册中心 Spring Cloud Eureka
  6. 代码不规范?985,211也不要!
  7. MagicHouse- 智能家居管理机器人 在线演示
  8. 常用软件分类运维或个人收藏软件必备,及文件夹打包下载
  9. uboot - 配置过程1(分析国产君正的ingenic-linux-kernel3.10.14-x1000-v8.2-20181116\u-boot\mkconfig脚本)
  10. 朱淑真 潸然看断梨花落
  11. 步态分析——信度以及效度
  12. LINUX下更新flash
  13. 视频图像的I帧、P帧、B帧详解
  14. 甬台温、温福铁路动车组时刻表
  15. 2022年湖南省自考考试学前教育行政与管理练习题及答案
  16. keras冻结_keras ”冻结“ 网络层
  17. 用jmeter压测tcp
  18. 看不到inter信息服务器,解决win10系统internet信息服务(iis)管理器找不到的方法
  19. java安卓屏幕护眼效果好_手机电脑用一天太伤眼!那是因为你不知道这些“护眼”的屏幕设置...
  20. 51单片机--SIM800C准备阶段<1>

热门文章

  1. 数独技巧-基础摒除法
  2. 百度百家号作者昵称、ID、粉丝数量获取
  3. 透过案例看清API接口的作用——演示1688商品详情接口
  4. 生产者消费者1.0(wait notify)
  5. Poi解析对比excel表格
  6. 速度与AI兼得:荣耀Play“GPU Turbo”是什么大杀技?
  7. JavaScript实现数字金额小写转大写
  8. 【数据字典】第三篇 利用PowDesigner自动生成数据字典
  9. 【Python爬虫案例教学】采集某网站壁纸,实现壁纸自由
  10. 赠书 |“硅谷精神之父”凯文·凯利:5000 天后的 “AI” 世界