您现在的位置:首页 >> 技术文章 >> MATLAB技术 >> 内容

FPGA代做-matlab图像代写编程光流场的交通汽车检测跟踪

时间:2018-3-26 14:42:38 点击:

  核心提示:FPGA代做-matlab图像代写编程光流场的交通汽车检测跟踪...
clear all
videofile = 'viptraffic.avi';
info = mmfileinfo(videofile);
cols=info.Video.Width;
rows=info.Video.Height;
hReader = vision.VideoFileReader(videofile,...
    'ImageColorSpace', 'RGB',...      
    'VideoOutputDataType', 'single'); 
hFlow = vision.OpticalFlow( ...
    'OutputValue', 'Horizontal and vertical components in complex form', ...
    'ReferenceFrameDelay', 3,...
    'Method','Horn-Schunck');
hMean1 = vision.Mean; 
hMean2 = vision.Mean('RunningMean', true); 
hFilter = vision.MedianFilter;
hClose = vision.MorphologicalClose('Neighborhood', strel('line',5,45));
hBlob = vision.BlobAnalysis(...
    'CentroidOutputPort', false,...
    'AreaOutputPort', true, ...
    'BoundingBoxOutputPort', true,...
    'OutputDataType', 'double', ...
    'MinimumBlobArea', 250,...
    'MaximumBlobArea', 3600,...
    'MaximumCount', 80);
hErode = vision.MorphologicalErode('Neighborhood', strel('square',2));
hShape1 = vision.ShapeInserter(...
    'BorderColor', 'Custom', ...
    'CustomBorderColor', [0 1 0]); 
hShape2 = vision.ShapeInserter(...
    'Shape','Lines', ...
    'BorderColor', 'Custom', ...
    'CustomBorderColor', [255 255 0]); 
hText = vision.TextInserter(...
    'Text', '%4d',...
    'Location',  [1 1], ...
    'Color', [1 1 1],...
    'FontSize', 12);
sz = get(0,'ScreenSize');  
pos = [(sz(3)-4*(cols+75))/2, (sz(4)-rows)/2 cols+60 rows+80];  
hVideo1 = vision.VideoPlayer('Name','Original Video','Position',pos);
pos(1) = pos(1)+cols+75;
hVideo2 = vision.VideoPlayer('Name','Motion Vector','Position',pos);
pos(1) = pos(1)+cols+75;
hVideo3 = vision.VideoPlayer('Name','Thresholded Video','Position',pos);
pos(1) = pos(1)+cols+75; 
hVideo4 = vision.VideoPlayer('Name','Results Video','Position',pos);
[xpos,ypos]=meshgrid(1:5:cols,1:5:rows);
xpos=xpos(:);
ypos=ypos(:);
locs=sub2ind([rows,cols],ypos,xpos);
while ~isDone(hReader)
    pause(0.3);
    frame  = step(hReader);
    gray = rgb2gray(frame);
    flow = step(hFlow, gray);
    lines = [xpos, ypos, xpos+20*real(flow(locs)), ypos+20*imag(flow(locs))];
    vector = step(hShape2, frame, lines);
    magnitude = flow .* conj(flow);
    threshold = 0.5 * step(hMean2, step(hMean1, magnitude));
    carobj = step(hFilter, magnitude >= threshold);
    carobj = step(hClose, step(hErode, carobj));
    [area, bbox] = step(hBlob, carobj);
    grow=22;
    idx = bbox(:,1) > grow;
    ratio = zeros(length(idx), 1);
    ratio(idx) = single(area(idx,1))./single(bbox(idx,3).*bbox(idx,4));
    flag = ratio > 0.4;
    count = int32(sum(flag));
    bbox(~flag, :) = int32(-1);
    result = step(hShape1, frame, bbox);
    result(grow:grow+1,:,:) = 1;
    result(1:15,1:30,:) = 0;
    result = step(hText, result, count);
    step(hVideo1, frame);  
    step(hVideo2, vector);    
    step(hVideo3, carobj);       
    step(hVideo4, result);    
end
release(hReader);

作者:不详 来源:网络
  • 您是如何找到本站的?
  • 百度搜索
  • Google搜索
  • 查阅资料过程中
  • 论坛发现
  • 百度贴吧发现
  • 朋友介绍
本站最新成功开发工程项目案例
相关文章
  • 没有相关文章
相关评论
发表我的评论
  • 大名:
  • 内容:
  • MATLAB代做,MATLAB专业代做,MATLAB淘宝代做(www.hslogic.com) © 2018 版权所有 All Rights Reserved.
  • Email:highspeed_logic@163.com 站长QQ: 1224848052

    专业代做/代写/承接、MATLAB、SIMULINK、FPGA项目、博士/硕士/本科毕业设计、课题设计、论文,毕业论文,Coursework、Eassy、Assignment