4

我正在尝试使用 OpenCV_Contrib 检测人脸的地标。然而,检测人脸地标存在一些问题。

我收到了一个需要使用“ https://github.com/opencv/opencv_3rdparty/blob/8afa57abc8229d611c4937165d20e2a2d9fc5a12/face_landmark_model.dat ”的答案。

它有效,但它检测到错误的面部标志。 在此处输入图像描述

为了使它完美,我必须找到 facemark->loadmodel("loadmodel") *68 points of face 需要什么模型

如何调用 FacemarkKazemi->loadModel();

请解决我的好奇心。

bool myDetector(cv::InputArray image, cv::OutputArray faces, cv::CascadeClassifier *face_cascade){
    cv::Mat gray;
    if (image.channels() > 1)
        cvtColor(image, gray, CV_BGR2GRAY);
    else
        gray = image.getMat().clone();
    equalizeHist(gray, gray);
    std::vector<cv::Rect> faces_;
    face_cascade->detectMultiScale(gray, faces_, 1.1, 3, 0, cv::Size(30, 30));
    cv::Mat(faces_).copyTo(faces);
    return true;
}
- (UIImage *) detectFacialLandmark:(UIImage *) image{
    double CurrentTime = CACurrentMediaTime();
    NSString *pathToFaceCascade = [[NSBundle mainBundle] pathForResource:@"haarcascade_frontalface_alt" ofType:@"xml"];
    NSString *pathToFaceModel = [[NSBundle mainBundle] pathForResource:@"face_landmark_model" ofType:@"dat"];
    cv::Mat faceImage;
    UIImageToMat(image, faceImage);
    cv::CascadeClassifier face_cascade;
    face_cascade.load([pathToFaceCascade UTF8String]);
    cv::face::FacemarkKazemi::Params params;
    cv::Ptr<cv::face::FacemarkKazemi> facemark = cv::face::FacemarkKazemi::create(params);
    facemark->setFaceDetector((cv::face::FN_FaceDetector)myDetector, &face_cascade);

    facemark->loadModel([pathToFaceModel UTF8String]);
    std::vector<cv::Rect> faces;
    facemark->getFaces(faceImage,faces);
    std::vector< std::vector<cv::Point2f> > shapes;
    if(faces.size() > 0){
        if(facemark->fit(faceImage,faces,shapes))
        {
            for( size_t i = 0; i < faces.size(); i++ )
            {
                cv::rectangle(faceImage, faces[i], cvScalar(255, 0, 0));
            }
            for(unsigned long i=0;i<faces.size();i++){
                for(unsigned long k=0;k<shapes[i].size();k++)
                    cv::circle(faceImage,shapes[i][k],5,cv::Scalar(0,0,255),cv::FILLED);
            }
        }
    }
    else{

    }
    UIImage *returnImage = MatToUIImage(faceImage);
    NSLog(@"test processing time : %f", (CACurrentMediaTime() - CurrentTime));
    return returnImage;
}
4

0 回答 0