how to get the facial feature points from the faces???
8 次查看(过去 30 天)
显示 更早的评论
Using the Viola Jones algorithm m able to detect the face parts. Now i want to extract the facial feature points from eyes,nose and mouth. how do i do that?? which method to use?? which function to use?? can anyone plz give me some suggestions..
5 个评论
回答(3 个)
Image Analyst
2013-8-12
I'm sure there are lots of published methods, and I don't work in the face recognition field, so you're best off looking up published papers of those who do. Look here for an algorithm that seems promising: Recognition, Detection, Tracking, Gesture Recognition, Fingerprints, Biometrics
4 个评论
Isha Pandya
2016-10-22
I have referred some of the published papers for facial feature extraction. They mentioned LDA is a good method for dimentionality reduction/ feature extraction. I have previously detected faces from images. Then I cropped the images to get full frontal view of the face. Now I want to extract facial features like eyes, Eyebrows and lips. And this should be done using LDA. But I am facing difficulty to do so. Can you please help me with the code?
Image Analyst
2016-10-22
Are their images color or monochrome? Are they using LDA on the original image or on the feature vectors?
Anand
2013-8-12
You can feed the bounding box of the detected face to any one of the feature detectors in the Computer Vision System Toolbox: detectFASTFeatures, detectHarrisFeatures, detectMinEigenFeatures, detectMSERFeatures or detectSURFFeatures. Here is an example of how to do this:
I = imread('visionteam.jpg');
% Detect faces
faceDetector = vision.CascadeObjectDetector;
bboxes = step(faceDetector, I);
% Select the first face
face = I(bboxes(1,2):bboxes(1,2)+bboxes(1,4),bboxes(1,1):bboxes(1,1)+bboxes(1,3));
% Detect SURF features
ftrs = detectSURFFeatures(face);
%Plot facial features.
imshow(face);hold on; plot(ftrs);
If you specifically want features around lets say the eyes, you can change the classification model to eyes and follow the same steps:
eyeDetector = vision.CascadeObjectDetector('eyepairsmall');
bboxes = step(eyeDetector,I);
6 个评论
sudeep g
2017-1-22
编辑:Walter Roberson
2018-8-11
I = imread('visionteam.jpg');
% Detect faces
faceDetector = vision.CascadeObjectDetector;
bboxes = step(faceDetector, I);
% Select the first face
face = I(bboxes(1,2):bboxes(1,2)+bboxes(1,4),bboxes(1,1):bboxes(1,1)+bboxes(1,3));
% Detect SURF features
ftrs = detectSURFFeatures(face);
%Plot facial features.
imshow(face);hold on; plot(ftrs);
4 个评论
Alawi Al-Saggaf
2022-2-23
How to compare two features for example ftrs1 of face1 and ftrs2 for face2.
What is the type of this ftr, it give me
3×1 SURFPoints array with properties:
Scale: [3×1 single]
SignOfLaplacian: [3×1 int8]
Orientation: [3×1 single]
Location: [3×2 single]
Metric: [3×1 single]
Count: 3
Sakshi
2023-10-16
@sudeep g Thank you so much for this code. They work fine for me, but I want to ask if one can modify the code so that it will detect each point and then provide the coordinates of each feature. My aim is to find the vertical and horizontal distances of the face (working on an animal's face), and the mean value needs to be measured. Can you help me provide this code?
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!