这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » DIY与开源设计 » 设计工具 » 上传一个自己用的:人脸识别的Matlab程序

共6条 1/1 1 跳转至

上传一个自己用的:人脸识别的Matlab程序

专家
2011-02-17 22:42:56     打赏

%保存文件时扩展名是.m文件,安装了matlab的话可以试一试,目前只针对单脸的效果很好
i=imread('face8.jpg');%把图片的名称改为:'face8
I=rgb2gray(i);
BW=im2bw(I);
figure,imshow(BW)

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%% minimisation of background portion

[n1 n2]=size(BW);
r=floor(n1/10);
c=floor(n2/10);
x1=1;x2=r;
s=r*c;

for i=1:10
    y1=1;y2=c;
    for j=1:10
        if (y2<=c | y2>=9*c) | (x1==1 | x2==r*10)
            loc=find(BW(x1:x2, y1:y2)==0);
            [o p]=size(loc);
            pr=o*100/s;
            if pr<=100
                BW(x1:x2, y1:y2)=0;
                r1=x1;r2=x2;s1=y1;s2=y2;
                pr1=0;
            end
            imshow(BW);
        end
            y1=y1+c;
            y2=y2+c;
    end
   
 x1=x1+r;
 x2=x2+r;
end
 figure,imshow(BW)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%% detection of face object

L = bwlabel(BW,8);
BB  = regionprops(L, 'BoundingBox');
BB1=struct2cell(BB);
BB2=cell2mat(BB1);

[s1 s2]=size(BB2);
mx=0;
for k=3:4:s2-1
    p=BB2(1,k)*BB2(1,k+1);
    if p>mx & (BB2(1,k)/BB2(1,k+1))<1.8
        mx=p;
        j=k;
    end
end
figure,imshow(I);
hold on;
rectangle('Position',[BB2(1,j-2),BB2(1,j-1),BB2(1,j),BB2(1,j+1)],'EdgeColor','r' )

可用此图片做实验:




关键词: 上传     一个     自己     用的     人脸     别的     Matlab         

专家
2011-02-18 14:19:13     打赏
2楼
人脸识别是图像处理的一个小小的分支

专家
2011-02-18 15:00:21     打赏
3楼
把你的图片放进去试一试?呵呵

专家
2011-02-18 16:05:09     打赏
4楼
这个程序对于单人脸识别的效果比较好,你把你自己的一个照片试一试,别的类似头像的外景没有的那种,这样的效果很好

专家
2011-02-18 16:29:16     打赏
5楼
啊?呵呵,看来程序还得再修改啊!!我试我的照片的时候也没啥问题!我再思考思考啊

专家
2011-02-24 17:05:12     打赏
6楼
说的比较有哲理啊

共6条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]