您现在的位置:首页 >> 机器学习 >> 内容

m基于GRNN广义回归神经网络和HOG特征提取的人体姿态检测识别matlab仿真,样本集为TOF深度

时间:2023/1/1 17:48:36 点击:

  核心提示:05_033_m,包括程序操作录像+说明文档...

1.完整项目描述和程序获取

>面包多安全交易平台:https://mbd.pub/o/bread/Y52bmZty

>如果链接失效,可以直接打开本站店铺搜索相关店铺:

点击店铺

>如果链接失效,程序调试报错或者项目合作可以加微信或者QQ联系。

2.部分仿真图预览





3.算法概述

       这里,通过TOF深度图拍摄相机获得人体不同动作姿态的深度图,其分辨率为1024*768,然后通过MATLAB软件设计本文所提出的动作姿态识别算法,通过该算法对TOF深度图进行识别,最后获得识别率。

   1). TOF深度图的采集;

        通过实验室的TOF深度图拍摄相机对不同人体动作姿态进行拍摄,获得一组动作姿态的连续图像序列。

   2). TOF深度图的预处理;

        对TOF深度图进行预处理,预处理主要通过MATLAB编程实现图像的预处理算法,主要包括图像灰度化,图像滤波去噪以及目标的提取等操作。

   3). 特征数据获取;

        对步骤2中获得的目标图像进行特征提取,将测试图像的特征数据随机分为两组,将一种一部分作为训练数据,另外一部分作为测试数据。

   4). 数据训练;

        通过训练算法对特征数据进行训练,获得识别模型。

   5). 对未知数据的测试和识别;

4.部分源码

.....................................

    %% 预处理:

    %第一步由于采集到的深度图有的地方的深度值为零,首先用最邻近差值算法将为零的深度值用其周围的点代替

    I2 = func_nearest_Interpolation(I1);

    subplot(222);

    imshow(uint8(I2));

    title('最邻近差值图像');

    %第二步:用中值滤波算法对上一步骤获得的图像进行处理,去噪声;

    L = 5;

    I3 = uint8(medfilt2(I2,[L,L]));

    subplot(223);

    imshow(I3);

    title('中值滤波');

    %第三步:获得二值图

    I4(1:floor(5*R1/7),:)    = im2bw(I3(1:floor(5*R1/7),:)   , 0.9*graythresh(I3(1:floor(5*R1/7),:)));

    I4(1+floor(5*R1/7):R1,:) = im2bw(I3(1+floor(5*R1/7):R1,:),1.25*graythresh(I3(1+floor(5*R1/7):R1,:)));

    subplot(224);

    imshow(I4);

    title('二值图'); 

    %第四步:边缘图

    I5 = edge(I4,'canny');

    %第5步:提取上半身

    [Is,indy] = func_bodycatch(I4);

    Is2       = bwareaopen(Is,4000);

    figure(2);

    subplot(121);

    imshow(Is);

    title('提取上半身'); 

    [RX,CX]= size(Is2);

    IIIs = zeros(RX,CX);

    for iii = 1:RX

        for jjj = 1:CX

            if Is2(iii,jjj) == 1

               IIIs(iii,jjj) =  I3(iii,jjj);

            end

        end

    end

    subplot(122);

    imshow(uint8(IIIs));

    title('提取上半身'); 

    %人体的提取

    ff          = uint8(255*Is2);

    [rows,cols] = size(ff);

    [Ls,n]      = bwlabel(ff);

    X1          = [];

    X2          = [];

    Y1          = [];

    Y2          = [];

    flag        = 0;

    L1          = zeros(R,C,3);

    S           = [];

    for i=1:n

        [r,c]     = find(Ls==i);

        a1(i)     = max(r);

        a2(i)     = min(r);

        b1(i)     = max(c);

        b2(i)     = min(c);

        w(i)      = b1(i)-b2(i);

        h(i)      = a1(i)-a2(i);

        S(i)      = w(i)*h(i);

        X1        = [X1,a2(i)];

        X2        = [X2,a1(i)];

        Y1        = [Y1,b2(i)];

        Y2        = [Y2,b1(i)];

        L1(a2(i):a2(i)+2,b2(i):b1(i),1) = 0;

        L1(a2(i):a2(i)+2,b2(i):b1(i),2) = 0;

        L1(a2(i):a2(i)+2,b2(i):b1(i),3) = 255;

        L1(1.2*a1(i)-2:1.2*a1(i),b2(i):b1(i),1) = 0;

        L1(1.2*a1(i)-2:1.2*a1(i),b2(i):b1(i),2) = 0;

        L1(1.2*a1(i)-2:1.2*a1(i),b2(i):b1(i),3) = 255;   

        L1(a2(i):1.2*a1(i),b1(i)-2:b1(i),1) = 0;

        L1(a2(i):1.2*a1(i),b1(i)-2:b1(i),2) = 0;

        L1(a2(i):1.2*a1(i),b1(i)-2:b1(i),3) = 255;

        L1(a2(i):1.2*a1(i),b2(i):b2(i)+2,1) = 0;

        L1(a2(i):1.2*a1(i),b2(i):b2(i)+2,2) = 0;

        L1(a2(i):1.2*a1(i),b2(i):b2(i)+2,3) = 255;   

    end

    if  length(S) > 1

        LL = L1;

        [V,I] = sort(S);

        inds  = I(end-1:end);

 

        [RR,CC] = size(Is2);

        IF      = zeros(RR,CC);

        for i = 1:RR

            for j = 1:CC

                if Is2(i,j) == 1

                   IF(i,j) = I1(i,j); 

                else

                   IF(i,j) = 0; 

                end

            end

        end

        if X1(inds(1)) < X1(inds(2))

           IF1 = IF(X1(inds(1)):min(X2(inds(1)),RR),Y1(inds(1)):Y2(inds(1)));

           XC1 = Y2(inds(1));

           YC1 = X1(inds(1));

           IF2 = IF(X1(inds(2)):min(X2(inds(2)),RR),Y1(inds(2)):Y2(inds(2)));

           XC2 = Y2(inds(2));

           YC2 = X1(inds(2)); 

        else

           IF2 = IF(X1(inds(1)):min(X2(inds(1)),RR),Y1(inds(1)):Y2(inds(1)));

           XC2 = Y2(inds(1));

           YC2 = X1(inds(1));

           IF1 = IF(X1(inds(2)):min(X2(inds(2)),RR),Y1(inds(2)):Y2(inds(2))); 

           XC1 = Y2(inds(2));

           YC1 = X1(inds(2)); 

        end

    end

    if  length(S) == 1

        [IF1,IF2,CUT,IFS,L1] = func_body_fenge(Is2,X1,X2,Y1,Y2);

        LL = L1;

        XC1 = Y2-30;

        YC1 = X1;

        XC2 = CUT-30;

        YC2 = X1; 

    end

..............................................

end

05_033_m

作者:我爱C编程 来源:我爱C编程
本站最新成功开发工程项目案例
相关评论
发表我的评论
  • 大名:
  • 内容:
本类固顶
  • 没有
  • FPGA/MATLAB商业/科研类项目合作(www.store718.com) © 2025 版权所有 All Rights Reserved.
  • Email:1480526168@qq.com 站长QQ: 1480526168