2016-07-22 3 views
1

Развейте: openface/issue/157Как разделить уровни каскадов в лобовом лицевом детекторе dlib?

Я пытаюсь разделить каскад пять уровней в детекторе лица dlib лобной на уровне трех (передний, передний вид, но повернута влево, и передний вид, но повернут вправо один)

Evgeniy предложил разбить детектор на C++. Я не знаком с C++. Когда я смотрю на frontal_face_detector.h, get_serialized_frontal_faces возвращает объект с кодировкой base64.

я узнал, как сохранить существующий детектор в .svm файл:

#include <dlib/image_processing/frontal_face_detector.h> 
#include <iostream> 

using namespace dlib; 
using namespace std; 

int main() 
{ 
    frontal_face_detector detector = get_frontal_face_detector(); 

    dlib::serialize("new_detector.svm") << detector; 

    std::cout<<"End of the Program"<<endl; 
    return 0; 
} 

Так как разделить каскад и сохранить новый детектор в .svm файл?

Также будет увеличиваться производительность детектора за счет снижения уровня пирамиды от < 6> до более низкого значения в frontal_face_detector.h?

ответ

5

Просто прочитайте object detector documentation и вы найдете объяснения. Вот код, который будет разделен детектор на части, восстановить оригинал и ограничить уровень пирамиды:

#include <dlib/image_processing/frontal_face_detector.h> 
#include <iostream> 
#include <string> 

using namespace dlib; 
using namespace std; 

int main() 
{ 
    frontal_face_detector detector = get_frontal_face_detector(); 

    dlib::serialize("current.svm") << detector; 

    std::vector<frontal_face_detector> parts; 
    // Split into parts and serialize to disk 
    for (unsigned long i = 0; i < detector.num_detectors(); ++i) 
    { 
     dlib::frontal_face_detector part(detector.get_scanner(), detector.get_overlap_tester(), detector.get_w(i)); 
     dlib::serialize("part" + std::to_string(i) + ".svm") << part; 
     parts.push_back(part); 
    } 

    // Reconstruct original detector 
    frontal_face_detector reconstructed(parts); 
    dlib::serialize("reconstructed.svm") << reconstructed; 

    // Create detector that will work only on one level of pyramid 
    typedef dlib::scan_fhog_pyramid<dlib::pyramid_down<6> > image_scanner_type; 
    image_scanner_type scanner; 
    scanner.copy_configuration(detector.get_scanner()); 
    scanner.set_max_pyramid_levels(1); //try setting to 2, 3... 
    frontal_face_detector one_level_detector = dlib::object_detector<image_scanner_type>(scanner, detector.get_overlap_tester(), detector.get_w()); 

    std::cout<<"End of the Program"<<endl; 
    return 0; 
} 

И НЕТ, изменяя уровень пирамиды из < 6> в любое другое значение, не поможет, потому что является не предел уровней пирамиды, но ее доля в масштабах пирамиды:

6 = 5/6

5 = 4/5

...

+0

Спасибо. Это сработало. Исправьте меня, если я ошибаюсь: 1. В соответствии с этим [комментарий] (https://github.com/davisking/dlib/blob/master/dlib/image_processing/frontal_face_detector.h#L29), часть - 0 является передней глядя, часть - 2 слева, часть - 3 выглядит правильно и так далее. 2. Если я хочу только смотреть влево и вправо, мне нужно оттолкнуть часть 1 и часть 2 на вектор частей и восстановить его. –

+0

Кроме того, что такое max_pyramid_levels в дефолтном фронтальном детекторе лица? Для меня set_max_pyramid_levels (8) работал на [маленькое лицо] (https://github.com/cmusatyalab/openface/blob/master/images/examples/clapton-2.jpg) и сравнительно [большое лицо] (https: // github.com/cmusatyalab/openface/blob/master/images/examples/lennon-2.jpg). –

+0

@vijayenthiransubramaniam, как я помню, он неограничен (1000 или около того) – Evgeniy