matlab跳动的心脏,Matlab视频处理心脏跳动.代码补充

我正在尝试编写代码帮助我完成生物学工作.

代码的概念是分析组织中收缩细胞的视频文件

示例2:youtube.com/watch?v=uG_WOdGw6Rk

并绘制出以下内容:

>每分钟节拍数.

>节奏强度

>殴打的规律性

所以我编写了一个Matlab代码,它将遍历视频并比较每个帧与其后的帧,并查看帧中是否有任何变化并在曲线上绘制这些变化.

我的代码结果示例

我编写的当前代码的核心:

for i=2:totalframes

compared=read(vidObj,i);

ref=rgb2gray(compared);%% convert to gray

level=graythresh(ref);%% calculate threshold

compared=im2bw(compared,level);%% convert to binary

differ=sum(sum(imabsdiff(vid,compared))); %% get sum of difference between 2 frames

if (differ ~=0) && (any(amp==differ)==0) %%0 is = no change happened so i dont wana record that !

amp(end+1)=differ; % save difference to array amp wi

time(end+1)=i/framerate; %save to time array with sec's, used another array so i can filter both later.

vid=compared; %% save current frame as refrence to compare the next frame against.

end

end

figure,plot(amp,time);

=====================

那就是我的代码,但有没有办法可以改进它,这样我可以获得更好的结果?

因为我觉得imabsdiff并不是我应该使用的,因为我的视频包含很多噪音并且影响我的结果很多,我认为我的所有放大器数据实际上都是假的!

另外我实际上只能通过计算峰值来提取跳动率,但是我如何改进我的代码以便能够从中获取所有必需的数据?

谢谢也非常感谢您的帮助,这是一小部分代码,如果您需要更多信息,请告诉我.

谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值