m基于PCA-SA低纬紧致姿态空间学习算法的单目视频人体姿态提取matlab仿真

简介: m基于PCA-SA低纬紧致姿态空间学习算法的单目视频人体姿态提取matlab仿真

1.算法仿真效果
matlab2013b仿真结果如下:

bed2a901088b0fb909404029996ef6e9_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
5eb0083328e72700d7cda04f43dc51ed_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
8197fa1ccd0b6f8dddf4c59a44b7ee75_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
9c65c4030f96f0296177c1f81a9006f3_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
473d783cad9721f3b31969ec2b3f8167_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
fb31e692a12a62b2071acb3d582cdd60_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
85ce4fb88070dd1e85ba3306908b104d_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
3fce0a6a8292924cda8e63d5b60c9005_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
fe6e8e47655be37bb02611a22d713510_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
139f59db9c4afce50d7fdfe6cd8b95f6_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
daf68fe28554b1c5762f7b81963f124e_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

2.算法涉及理论知识概要

659050a8be112d1072aed5d45df2b8ea_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

    介绍了运动人体的剪影提取,在视频序列中,由于受到复杂背景、遮挡、光照变化等因素的影响,通常的背景分离算法无法有效的对运动人体进行提取,本文介绍了一种基于高斯混合模型和帧差法相结合的运动目标提取算法,从而获得了精度较高的运动人体剪影。

    由于人体姿态运动数据通常是高维矩阵数据,在处理之前一般需要进行降维度处理,首先通过传统的PCA降维算法进行处理。然后分析了PCA算法的缺陷和不足,并在PCA算法的基础上提出了一种基于概率信息的改进PCA算法。在PCA的基础上,加入一个噪声变量,用来调整后面N-M个高维度的数据的精度。 通过最大似然估计进行估计这个噪声模型,然后叠加到PCA模型的高维数据上。

   对降维后的数据进行粒子群的姿态估计,这里首先使用PSO粒子群优化算法进行优化,然后使用模拟退火算法进行优化,最后通过对比分析,提出了一种基于基因突变的变权值模拟退火粒子群优化算法,通过该算法,可以大大改进最后的收敛效果,使得最后的收敛值趋于稳定收敛,收敛值达到更小的误差水平,并且不存在粒子突变的情况。

最后,对CMU数据库中的不同运动姿态进行仿真,实验结果仿真可知本文方法不仅具有良好的计算效率,同时具有良好的收敛性和全局搜索能力,能准确估计和跟踪单目视频中的人体姿态。

    目前,运动捕获数据有多种格式,应用较为广泛的主要有BVH、ASF/AMC、FBK、C3D以及HTR等。其中ASF/AMC是最常用的数据格式。因此,这里,我们重点对ASF/AMC的数据格式进行介绍。

     ASF/AMC,全称Acclaim Skeleton File/Acclaim Motion Data,其主要由两个文件组成:一个骨架文件和一个运动文件。ASF是骨架文件,AMC是运动文件,对于每一个特定的动作,都是由骨架来完成的,这些数据,可以从CMU数据库中获得。

  下面对ASF骨架数据进行简单的介绍,其基本结构如下图所示:

f56af9731db7bf9d79d1c5fcaeab0205_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

“:version”指示出骨架定义的版本;

“:name”允许对骨架数据进行命名;

“:units”定义了各种类型数据的单位和一些参数的默认值;

“:documentation”存储的是一些起到说明作用的文档信息;

    “:root”部分定义了场景中一个特定的片段,它是骨架层次结构中的根节点,除了不包含方向和长度信息之外,和其他关节是一样的。其中”axis”定义了根对象的旋转顺序,”order”指出了应用于根节点的运动通道信息,并将以这样的顺序出现在AMC文件中。”Position”和”orientation”后面的信息给出了根节点的起始位置和方位,一般情况下都是0。

    “:bonedata”部分对于层次结构中的其他骨骼信息分别进行了描述,对每个骨骼的定义都是以”begin”,开始,以”end”结束的。在对各个骨骼的定义中,包含以下几个部分:”id”是一个唯一的数字,标识了当前骨骼的序号,这一项并不是必须的,因为每段骨骼都有自己的名称,而且这个名称在层次部分和AMC文件中都被用到。”name”定义了骨骼的名称,需要注意的是,每个骨骼必须有一个唯一的名称。”direction”指出了骨骼的方向,根据该信息,可以知道如何绘制该骨骼,并定义了从父骨骼到子骨骼的方向。方向信息和长度信息决定了一个骨骼相对于其父骨骼的偏移量。”length”定义了骨骼的长度信息。”axis”部分给出了骨骼的旋转轴。通过将旋转轴指定为一个独立的值,运动数据可以独立于绘制和层次信息,这对于那些需要解决万向节死锁问题的应用来说显得尤为重要。”dof”指定了运动通道的数量和这些通道在AMC文件中出现的顺序。如果某个骨骼不包含”dof”部分,那就认为该骨骼没有任何运动数据。”limits”部分给出了自由度中指定的通道的限制信息。对于每个通道而言,限制信息都是以一对数字的形式给出的,规定了该通道允许的最小值和最大值,在运动编辑等过程中,这部分数据用来限制旋转的范围。

“:hierarchy“部分描述了各段骨骼之间的层次关系。

3.MATLAB核心程序
```if Start(1) == 1
disp('read the avi...');
[Obj,frameNum_Original] = get_AVI(FileName_AVI);
%将视频保存为jpg形式,方便对比处理
[pixel_original,pixel_gray] = vedio_op(Obj,frameNum_Original);

[RR,CC,KK] = size(pixel_gray);

for i = 1:min(frameNum_Original,Process_frames)
pixel_gray2(:,:,i) = imresize(pixel_gray(:,:,i),[RR/2,CC/2]);
pixel_original2(:,:,:,i) = imresize(pixel_original(:,:,:,i),[RR/2,CC/2]);
end

%保存数据
save Save_Temp\Start1\Start01.mat pixel_gray2 frameNum_Original RR CC
save Save_Temp\Start1\Start02.mat pixel_original2 frameNum_Original RR CC

clear Obj pixel_original pixel_gray pixel_original2 pixel_gray2 frameNum_Original
disp('read the avi over...');
pause(8);
close all;
end

....................................................................
figure;
for tt = 1:min(frameNum_Original,Process_frames)
tt
subplot(221)
imshow(image_sequence2(:,:,:,tt));
title('原始图像');
subplot(222)
imshow(uint8(background_Update2));
title('背景图像更新');
subplot(223)
imshow(Images02(:,:,tt));
title('运动目标检测');
subplot(224)
imshow(Images22(:,:,tt));
title('运动目标提取');
pause(0.2);
end

clear image_sequence2 background_Update2 Images02 Images22 pixel_original2 frameNum_Original2 RR CC
disp('Get the Background over...');
pause(8);
close all;
end
```

相关文章
|
1天前
|
机器学习/深度学习 算法 计算机视觉
m基于Yolov2深度学习网络的智能零售柜商品识别系统matlab仿真,带GUI界面
MATLAB 2022a中展示了YOLOv2目标检测算法的仿真结果,包括多张检测图像。YOLOv2是实时检测算法,由卷积层和全连接层构成,输出张量包含边界框坐标和类别概率。损失函数由三部分组成。程序使用75%的数据进行训练,剩余25%作为测试集。通过ResNet-50预训练模型构建YOLOv2网络,并用SGDM优化器进行训练。训练完成后,保存模型为`model.mat`。
14 2
|
2天前
|
机器学习/深度学习 算法 数据挖掘
基于PSO优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
摘要: 本文介绍了运用粒子群优化(PSO)调整深度学习模型超参数以提升时间序列预测性能的方法。在比较了优化前后的效果(Ttttttttttt12 vs Ttttttttttt34)后,阐述了使用matlab2022a软件的算法。文章详细讨论了CNN、GRU网络和注意力机制在时间序列预测中的作用,以及PSO如何优化这些模型的超参数。核心程序展示了PSO的迭代过程,通过限制和调整粒子的位置(x1)和速度(v1),寻找最佳解决方案(gbest1)。最终,结果保存在R2.mat文件中。
基于PSO优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
|
3天前
|
存储 算法
m考虑时偏影响的根升余弦滤波器matlab仿真
MATLAB 2022a仿真实现了根升余弦滤波器(RRC)的效果,该滤波器常用于通信系统以消除码间干扰。RRC滤波器设计考虑了时偏影响,其脉冲响应由理想矩形脉冲卷积得到,滚降系数控制衰减速度。在有同步误差时,滤波器需保持良好ISI抑制能力。MATLAB代码展示了计算时偏量并应用RRC滤波于连续样本的过程,以降低误码率并优化系统性能。
11 2
|
3天前
|
算法 数据安全/隐私保护 数据格式
基于混沌序列的图像加解密算法matlab仿真,并输出加解密之后的直方图
该内容是一个关于混沌系统理论及其在图像加解密算法中的应用摘要。介绍了使用matlab2022a运行的算法,重点阐述了混沌系统的特性,如确定性、非线性、初值敏感性等,并以Logistic映射为例展示混沌序列生成。图像加解密流程包括预处理、混沌序列生成、数据混淆和扩散,以及密钥管理。提供了部分核心程序,涉及混沌序列用于图像像素的混淆和扩散过程,通过位操作实现加密。
|
2月前
|
机器学习/深度学习 算法
m基于深度学习的64QAM调制解调系统频偏估计和补偿算法matlab仿真
### 算法仿真结果 展示5张图像,描绘了基于深度学习的频偏估计和补偿在MATLAB 2022a中的仿真效果。 ### 理论概要 - 深度学习算法用于建立信号与频偏的非线性映射,无需导频,节省资源。 - 网络模型(如CNN或RNN)处理IQ数据,提取特征,简化估计补偿过程,降低复杂度。 - 64QAM系统中,通过神经网络实现精确频偏感知,增强通信性能。 ### MATLAB核心程序 - 代码生成64QAM信号,模拟不同SNR和频偏条件,使用深度学习进行相位估计和补偿。 - 仿真比较了有无补偿的误码率,显示补偿能显著改善通信质量。 ```
31 1
|
10天前
|
机器学习/深度学习 人工智能 算法
基于DCT和扩频的音频水印嵌入提取算法matlab仿真
本文介绍了结合DCT和扩频技术的音频水印算法,用于在不降低音质的情况下嵌入版权信息。在matlab2022a中实现,算法利用DCT进行频域处理,通过扩频增强水印的隐蔽性和抗攻击性。核心程序展示了水印的嵌入与提取过程,包括DCT变换、水印扩频及反变换步骤。该方法有效且专业,未来研究将侧重于提高实用性和安全性。
|
25天前
|
机器学习/深度学习 算法
【MATLAB】GA_BP神经网络时序预测算法
【MATLAB】GA_BP神经网络时序预测算法
35 8
|
29天前
|
机器学习/深度学习 算法 Serverless
【MATLAB】PSO_BP神经网络回归预测算法(适用光伏发电回归预测等)
【MATLAB】PSO_BP神经网络回归预测算法(适用光伏发电回归预测等)
30 1
|
1天前
|
算法 TensorFlow 算法框架/工具
基于直方图的图像阈值计算和分割算法FPGA实现,包含tb测试文件和MATLAB辅助验证
这是一个关于图像处理的算法实现摘要,主要包括四部分:展示了四张算法运行的效果图;提到了使用的软件版本为VIVADO 2019.2和matlab 2022a;介绍了算法理论,即基于直方图的图像阈值分割,通过灰度直方图分布选取阈值来区分图像区域;并提供了部分Verilog代码,该代码读取图像数据,进行处理,并输出结果到"result.txt"以供MATLAB显示图像分割效果。
|
1天前
|
算法 搜索推荐 数据挖掘
MATLAB模糊C均值聚类FCM改进的推荐系统协同过滤算法分析MovieLens电影数据集
MATLAB模糊C均值聚类FCM改进的推荐系统协同过滤算法分析MovieLens电影数据集

热门文章

最新文章